/* ============================================================
   Kids Kare Schools - site.css
   Unified stylesheet extracted from canonical mockup HTML files.
   Organized by: variables, reset, shared, topbar, footer,
   then page-specific sections.
   ============================================================ */

/* ============ Variables ============ */
:root{
  --bg:        #F4F8FB;
  --paper:     #FFFFFF;
  --ink:       #0C2A45;
  --ink-soft:  #5A748A;
  --line:      #E4ECF3;
  --line-soft: #EEF3F8;

  --sky:       #1A6FB5;
  --sky-deep:  #0B4F86;
  --sky-darker:#073E6B;
  --sky-soft:  #E4EFF8;

  --coral:     #F26A56;
  --coral-deep:#D64A36;
  --mint:      #3FB28E;
  --lavender:  #7A66C4;
  --pink:      #E9628A;
  --sun:       #FFC857;

  --r:         14px;
  --r-lg:      20px;
  --shadow-xs: 0 1px 2px rgba(11,79,134,.06);
  --shadow-sm: 0 2px 4px rgba(11,79,134,.04), 0 6px 14px -6px rgba(11,79,134,.08);
  --shadow-md: 0 4px 8px rgba(11,79,134,.05), 0 20px 40px -20px rgba(11,79,134,.18);
}

/* ============ Reset & Base ============ */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  font-family:'Nunito', system-ui, sans-serif;
  color:var(--ink);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Outfit', system-ui, sans-serif; color:var(--ink); margin:0; letter-spacing:-.015em}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}

.wrap{max-width:1400px; margin:0 auto; padding:0 40px}

/* ============ Topbar (compact white) ============ */
.topbar{
  background:#FFFFFF;
  border-bottom:1px solid var(--line);
  position:sticky; top:0; z-index:100;
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{
  width:46px; height:46px;
  display:grid; place-items:center;
  filter: drop-shadow(0 2px 0 rgba(0,0,0,.06)) drop-shadow(0 6px 14px rgba(11,79,134,.20));
}
.brand-mark img{width:100%; height:100%; object-fit:contain; display:block}
.brand-text{display:flex; flex-direction:column; line-height:1.05}
.brand-text .wm{
  font-family:'Outfit'; font-weight:800; font-size:22px;
  color:var(--ink); letter-spacing:.005em;
  white-space:nowrap;
}
.brand-text .wm sup{font-size:9px; color:var(--ink-soft); font-weight:700; margin-left:2px}
.brand-text .tg{
  font-family:'Outfit'; font-weight:600; font-size:12px;
  color:var(--ink-soft); letter-spacing:.28em; margin-top:1px;
}

.top-nav{display:flex; gap:6px; flex:1; justify-content:center}
.top-nav > .nav-item{position:relative}
.top-nav a{
  padding:10px 16px;
  font-family:'Outfit'; font-weight:600; font-size:14px;
  color:var(--ink); border-radius:10px;
  transition:background .15s, color .15s;
  white-space:nowrap;
  display:inline-flex; align-items:center; gap:6px;
}
.top-nav a:hover{background:var(--sky-soft); color:var(--sky-deep)}
.top-nav a.on{color:var(--sky-deep); position:relative}
.top-nav a.on::after{
  content:""; position:absolute; left:30%; right:30%; bottom:2px;
  height:2px; border-radius:2px; background:var(--sky);
}
.top-nav .caret{
  width:0; height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:5px solid currentColor;
  opacity:.5;
  margin-top:1px;
}
.nav-drop{
  position:absolute; top:calc(100% + 8px); left:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow-md);
  padding:8px;
  min-width:220px;
  opacity:0; visibility:hidden; transform:translateY(-4px);
  transition:opacity .14s ease, transform .14s ease, visibility .14s;
  z-index:120;
}
.nav-item:hover .nav-drop,
.nav-item:focus-within .nav-drop{
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav-drop a{
  display:flex; align-items:center; gap:10px;
  padding:9px 12px;
  border-radius:9px;
  font-size:13.5px; font-weight:600;
  color:var(--ink);
}
.nav-drop a:hover{background:var(--sky-soft); color:var(--sky-deep)}
.nav-drop a.on{background:var(--sky-soft); color:var(--sky-deep)}
.nav-drop a .dd-ico{
  width:18px; height:18px; color:var(--sky);
  display:grid; place-items:center;
}

.top-cta{display:flex; gap:8px; align-items:center}
.pill{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content: center;
  padding:9px 14px 9px 12px;
  border-radius:999px;
  font-family:'Outfit';
  font-weight:700;
  font-size:13px;
  transition:transform .12s ease, background .15s, color .15s;
  white-space:nowrap;
}
.pill.ghost{
  background:var(--sky-soft); color:var(--sky-deep);
}
.pill.ghost:hover{background:var(--sky); color:#fff}
.pill.solid{
  background:var(--sky-deep); color:#fff;
  box-shadow:0 3px 0 var(--sky-darker), 0 6px 14px rgba(11,79,134,.25);
}
.pill.solid:hover{transform:translateY(-1px)}


/* ============ Shared: Page Head (subpages) ============ */
.page-head{
  background:
    radial-gradient(circle at 90% 10%, #DDEDF7 0%, transparent 50%),
    radial-gradient(circle at 0% 100%, #FFE8C1 0%, transparent 45%),
    linear-gradient(180deg, #F4F8FB 0%, #ECF3F8 100%);
  padding:16px 0 44px;
}
.crumbs{
  font-family:'Outfit'; font-weight:700; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:8px;
}
.crumbs .sep{opacity:.4}
.crumbs .here {
  color:var(--sky-deep);
  display: none;
}
.crumbs a.activeroute{ color:#e32c80; }
.crumbs a.activeroute:hover{ color:#c01f6b; }
.page-head h1{font-size:54px; font-weight:800; letter-spacing:-.025em; margin:14px 0 10px; line-height:1}
.page-head p{margin:0; max-width:60ch; font-size:17px; color:var(--ink-soft)}
.page-head .lede{margin:14px 0 0; max-width:64ch; font-size:20px; line-height:1.45; color:var(--sky-deep); font-family:'Outfit'; font-weight:600; font-style:italic}

/* Shared section header */
.sec-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin:0 0 28px;
}
.sec-head .eyebrow{
  font-family:'Outfit'; font-weight:800; font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--sky); margin-bottom:6px;
}
.sec-head h2{font-size:36px; font-weight:800; letter-spacing:-.02em}
.sec-head p{color:var(--ink-soft); margin:8px 0 0; font-size:16px; max-width:62ch}
.sec-head .link{font-weight:700; color:var(--sky-deep); font-size:14px}
.sec-head .link::after{content:" \2192"}

/* Shared button styles */
.btn-prim{
  background:var(--coral); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:15px;
  padding:14px 22px; border-radius:12px;
  box-shadow:0 4px 0 var(--coral-deep), 0 8px 18px rgba(242,106,86,.35);
  transition:transform .12s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.btn-prim:hover{transform:translateY(-2px)}
.btn-prim:disabled{opacity:.55; transform:none; cursor:not-allowed; box-shadow:0 4px 0 var(--coral-deep)}
/* Light-blue sibling of .btn-prim (same shape, sky palette) */
.btn-prim-light{
  background:var(--sky); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:15px;
  padding:14px 22px; border-radius:12px;
  box-shadow:0 4px 0 var(--sky-deep), 0 8px 18px rgba(11,79,134,.28);
  transition:transform .12s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.btn-prim-light:hover{transform:translateY(-2px)}
.btn-link{
  color:var(--sky-deep); font-weight:800; font-size:15px;
  padding:14px 4px;
}
.btn-link::after{content:" \2192"; font-weight:800}
.btn-ghost{
  padding:13px 16px; border-radius:11px;
  background:var(--sky-soft); color:var(--sky-deep);
  font-family:'Outfit'; font-weight:700; font-size:14px;
}
.btn-light{
  background:rgba(255,255,255,.14); color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  font-family:'Outfit'; font-weight:700; font-size:14px;
  padding:13px 20px; border-radius:11px;
}
.btn-light:hover{background:rgba(255,255,255,.22)}

/* Shared eyebrow (standalone) */
.eyebrow{font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--sky); margin-bottom:8px}

/* Shared .body wrapper */
.body{padding:48px 0 0}

/* Shared .sec section */
.sec{padding:80px 0 0}

/* Shared read-more */
.read-more{
  align-self:flex-start; color:var(--sky-deep);
  font-family:'Outfit'; font-weight:800; font-size:13px;
  border-bottom:2px solid var(--sky);
  padding-bottom:2px;
  transition:color .15s;
}
.read-more:hover{color:var(--coral); border-color:var(--coral)}


/* ============ HERO BAND (Home page) ============ */
.hero-band{
  background:
    radial-gradient(circle at 90% 10%, #DDEDF7 0%, transparent 50%),
    radial-gradient(circle at 0% 100%, #FFE8C1 0%, transparent 45%),
    linear-gradient(180deg, #F4F8FB 0%, #ECF3F8 100%);
  padding:48px 0 56px;
  position:relative;
}
.hero{
  display:grid;
  grid-template-columns: 1.6fr 1fr;
  gap:48px;
  align-items:stretch;
}
.hero-left{display:grid; grid-template-columns: 1fr 1fr; gap:36px; align-items:center}
.hero-img{
  aspect-ratio: 4/5;
  border-radius:var(--r-lg);
  background:repeating-linear-gradient(135deg, #FCEBC8 0 16px, #FFDDA5 16px 32px);
  display:grid; place-items:center;
  position:relative;
  box-shadow:var(--shadow-md);
  overflow:hidden;
  height: 168px;
  width: 100%;
}
@media (min-width:1025px){
  .hero-img{ aspect-ratio: 3/4; height:auto; }
}
.hero-img::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.18));
}
.hero-img .lbl{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  background:rgba(255,255,255,.92); color:#7A5418;
  padding:7px 12px; border-radius:6px;
  position:relative; z-index:2;
}
.hero-copy{display:flex; flex-direction:column; justify-content:center}
.hero-eye{
  display:inline-flex; align-items:center; gap:8px;
  background:#FFE3DE; color:#C73E2A;
  font-weight:800; font-size:11px; letter-spacing:.16em;
  padding:6px 12px; border-radius:999px;
  width:fit-content; text-transform:uppercase;
}
.hero-copy h1{
  font-size:72px; line-height:.95; font-weight:800;
  margin:18px 0 0;
  letter-spacing:-.025em;
}
.hero-copy h1 .accent{color:var(--sky-deep)}
.hero-copy p{
  margin:16px 0 0; font-size:18px; color:var(--ink-soft);
  max-width:40ch;
}
.hero-cta{margin-top:28px; display:flex; gap:10px; align-items:center; flex-wrap:nowrap}
/* Keep both CTAs on one row inside the narrow hero column */
.hero-cta .btn-prim, .hero-cta .btn-prim-light{ padding:13px 18px; font-size:14px; white-space:nowrap; flex:0 1 auto; }
@media (max-width:380px){ .hero-cta{ flex-wrap:wrap; } }

/* Programs sidebar (Home hero) */
.programs-side{display:flex; flex-direction:column; justify-content:center; gap:10px}
.programs-side h3{
  font-family:'Outfit'; font-weight:800;
  font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink-soft);
  margin-bottom:6px;
}
.program-row{
  display:flex; align-items:center; gap:14px;
  padding:14px 16px;
  background:#FFFFFF;
  border:1px solid var(--line);
  border-radius:var(--r);
  transition:transform .15s, border-color .15s;
  cursor:pointer;
}
.program-row:hover{transform:translateX(3px); border-color:var(--sky)}
.program-row .av{
  width:46px; height:46px; border-radius:50%;
  display:grid; place-items:center;
  box-shadow:inset 0 0 0 3px #fff, 0 0 0 1.5px var(--line);
}
.av.tod{background:linear-gradient(135deg,#E8D5F5,#C9A6E8)}
.av.pre{background:linear-gradient(135deg,#FFE0A8,#FFB454)}
.av.gra{background:linear-gradient(135deg,#B6E7DD,#5BC9AD)}
.program-row .av svg{width:24px; height:24px; opacity:.92}
.program-row .nm{font-family:'Outfit'; font-weight:700; font-size:15px}
.program-row .ag{font-size:11px; color:var(--ink-soft); letter-spacing:.06em; text-transform:uppercase; font-weight:600; margin-top:2px}
.program-row .ar{
  margin-left:auto;
  color:var(--ink-soft);
  font-weight:800;
  opacity:0.5;
  transition:opacity .15s, transform .15s;
  font-size: xx-large;

}
.program-row:hover .ar{opacity:1; transform:translateX(2px)}

.hero-dots{
  display:flex; justify-content:center; gap:8px;
  margin-top:36px;
}
.hero-dots span{
  width:8px; height:8px; border-radius:50%;
  background:#CDDBE6; cursor:pointer;
}
.hero-dots span.on{background:var(--sky); width:22px; border-radius:4px}


/* ============ Media row (Video gallery + Locations) ============ */
.media{padding:72px 0 0}
.media-grid{
  display:grid;
  grid-template-columns: 1.6fr 1fr;
  gap:40px;
  align-items:flex-start;
}
.media-grid > *{min-width:0}
.pb-track-wrap{min-width:0}

.video-frame{
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  aspect-ratio: 16/9;
  background:
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.45)),
    repeating-linear-gradient(135deg, #B5DDD2 0 18px, #9FCDC0 18px 36px);
  display:grid; place-items:center;
  cursor:pointer;
  box-shadow:var(--shadow-md);
}
.video-frame .play{
  width:84px; height:84px; border-radius:50%;
  background:rgba(255,255,255,.95);
  display:grid; place-items:center;
  box-shadow:0 12px 30px rgba(0,0,0,.3);
  transition:transform .2s ease;
}
.video-frame:hover .play{transform:scale(1.06)}
.video-frame .play::after{
  content:""; width:0; height:0;
  border-left:24px solid var(--coral);
  border-top:15px solid transparent;
  border-bottom:15px solid transparent;
  margin-left:6px;
}
.video-meta{position:absolute; left:20px; top:20px; display:flex; align-items:center; gap:10px}
.yt-badge{background:#fff; color:#222; padding:6px 10px; border-radius:8px; font-weight:700; font-size:11px; display:flex; align-items:center; gap:6px}
.yt-badge .dot{width:14px; height:14px; background:#FF0033; border-radius:3px}
.v-title{color:#fff; font-weight:700; font-size:15px; text-shadow:0 1px 6px rgba(0,0,0,.5)}

.v-thumbs{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
  margin-top:18px;
}
.v-thumb{
  aspect-ratio: 4/3;
  border-radius:var(--r);
  border:2px solid transparent;
  overflow:hidden; position:relative; cursor:pointer;
  transition:transform .15s, border-color .15s;
}
.v-thumb:hover{transform:translateY(-2px)}
.v-thumb.on{border-color:var(--sky)}
.v-thumb .img{
  width:100%; height:100%;
  display:grid; place-items:center;
  font-family:'JetBrains Mono', monospace; font-size:9px; color:rgba(255,255,255,.85);
}
.v-thumb.t1 .img{background:repeating-linear-gradient(135deg,#F8C5B0 0 14px,#E59E83 14px 28px)}
.v-thumb.t2 .img{background:repeating-linear-gradient(135deg,#C9D8E6 0 14px,#A4BAD0 14px 28px)}
.v-thumb.t3 .img{background:repeating-linear-gradient(135deg,#D5C7E8 0 14px,#B19EDE 14px 28px)}
.v-thumb.t4 .img{background:repeating-linear-gradient(135deg,#B6E7DD 0 14px,#8FCDBC 14px 28px)}
.v-thumb .cap{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.55));
  color:#fff; padding:14px 10px 8px;
  font-family:'Outfit'; font-size:11px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
}

/* Gallery carousel */
.photo-bar{margin-top:28px}
.pb-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:14px;
}
.pb-title{font-family:'Outfit'; font-weight:800; font-size:14px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-deep); display:flex; align-items:center; gap:10px}
.pb-title .dot{width:7px; height:7px; border-radius:50%; background:var(--coral)}
.pb-meta{font-size:12px; color:var(--ink-soft); font-weight:700}
.pb-meta b{color:var(--ink)}
.pb-track-wrap{position:relative}
.pb-track{
  display:flex; gap:12px;
  overflow-x:auto; scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding-bottom:6px;
}
.pb-track::-webkit-scrollbar{height:6px}
.pb-track::-webkit-scrollbar-thumb{background:#CDDBE6; border-radius:3px}
.pb-slide{
  flex:0 0 auto;
  width:200px; aspect-ratio: 4/3;
  border-radius:var(--r);
  overflow:hidden; scroll-snap-align:start;
  position:relative; cursor:pointer;
  transition:transform .15s;
}
.pb-slide:hover{transform:translateY(-2px)}
.pb-slide .img{
  width:100%; height:100%;
  display:grid; place-items:center;
  font-family:'JetBrains Mono', monospace; font-size:10px; color:rgba(255,255,255,.85);
}
.pb-slide.c1 .img{background:repeating-linear-gradient(135deg,#F4C9D7 0 14px,#E199B0 14px 28px)}
.pb-slide.c2 .img{background:repeating-linear-gradient(135deg,#FFE0A8 0 14px,#FFB454 14px 28px)}
.pb-slide.c3 .img{background:repeating-linear-gradient(135deg,#C7E5A8 0 14px,#9CD27A 14px 28px)}
.pb-slide.c4 .img{background:repeating-linear-gradient(135deg,#BFDEF1 0 14px,#83B7DC 14px 28px)}
.pb-slide.c5 .img{background:repeating-linear-gradient(135deg,#E1D2F2 0 14px,#B79CDC 14px 28px)}
.pb-slide.c6 .img{background:repeating-linear-gradient(135deg,#FFCCB8 0 14px,#F09679 14px 28px)}
.pb-slide.c7 .img{background:repeating-linear-gradient(135deg,#B8E2D8 0 14px,#7AC8B6 14px 28px)}
.pb-slide.c8 .img{background:repeating-linear-gradient(135deg,#F4D9A6 0 14px,#E0AE65 14px 28px)}
.pb-slide .cap{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.6));
  color:#fff; padding:18px 10px 8px;
  font-family:'Outfit'; font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
}
.pb-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px; border-radius:50%;
  background:#fff; color:var(--sky-deep);
  box-shadow:var(--shadow-md);
  display:grid; place-items:center;
  font-weight:800; font-size:18px; z-index:2;
  transition:transform .15s;
}
.pb-nav:hover{transform:translateY(-50%) scale(1.06)}
.pb-nav.prev{left:-14px}
.pb-nav.next{right:-14px}


/* ============ Locations rail ============ */
.loc{
  background:#fff;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.loc-map{
  height:280px;
  border-bottom:1px solid var(--line);
  position:relative;
}
#leaflet-map{width:100%; height:100%}
.map-pill{
  position:absolute; left:14px; top:14px;
  background:#fff; padding:8px 12px;
  border-radius:10px;
  font-size:12px; font-weight:700;
  color:var(--ink);
  display:flex; align-items:center; gap:8px;
  box-shadow:var(--shadow-sm);
  z-index:401;
}
.map-pill .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--coral); box-shadow:0 0 0 4px rgba(242,106,86,.25);
}
.kk-pin{
  width:24px; height:24px; border-radius:50% 50% 50% 0;
  background:var(--coral); transform:rotate(-45deg);
  border:2.5px solid #fff;
  box-shadow:0 3px 8px rgba(0,0,0,.3);
  display:grid; place-items:center;
}
.kk-pin::after{content:""; width:6px; height:6px; border-radius:50%; background:#fff}
.kk-pin.clovis{background:var(--sky)}
.kk-pin.madera{background:var(--lavender)}
.leaflet-tooltip.kk-tip{
  background:#fff; color:var(--ink);
  border:1px solid var(--line);
  border-radius:8px; padding:5px 9px;
  font-weight:700; font-size:11px;
  box-shadow:var(--shadow-sm);
}

.loc-body{padding:22px 24px}
.loc-region{margin-bottom:18px}
.loc-region:last-child{margin-bottom:0}
.loc-region h5{
  font-size:12px; font-weight:800; letter-spacing:.18em;
  color:var(--sky-deep); text-transform:uppercase;
  padding-bottom:8px; margin-bottom:10px;
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}
.loc-region h5 .ct{
  background:var(--sky-soft); color:var(--sky-deep);
  padding:2px 8px; border-radius:999px;
  font-size:10px; letter-spacing:.06em;
}
.loc-list{display:flex; flex-direction:column; gap:1px}
.loc-link{
  display:flex; align-items:center; gap:10px;
  padding:7px 10px; border-radius:8px;
  font-weight:600; font-size:13.5px;
  cursor:pointer;
  transition:background .12s, color .12s;
}
.loc-link:hover{background:var(--sky-soft); color:var(--sky-deep)}
/* Randomly-featured center gets a deep-blue waterslide badge on its own line (bottom) */
.loc-link.has-waterslide{ flex-wrap:wrap; }
.loc-waterslide{
  flex-basis:100%; margin-top:4px; margin-left:16px;
  display:inline-flex; align-items:center; gap:6px; width:max-content;
  background:var(--sky-deep); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.01em;
  padding:4px 10px; border-radius:99px;
}
.loc-waterslide svg{ width:13px; height:13px; }
.loc-link .mk{
  width:6px; height:6px; border-radius:50%;
  background:var(--coral);
}
.loc-list.clovis .mk{background:var(--sky)}
.loc-list.madera .mk{background:var(--lavender)}


/* ============ News (Home page) ============ */
.news{padding:80px 0 0}
.news-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:32px;
}
.news-item{display:flex; flex-direction:column}
.news-img{
  aspect-ratio: 4/3;
  border-radius:var(--r-lg);
  margin-bottom:18px;
  display:grid; place-items:center;
  font-family:'JetBrains Mono', monospace; font-size:11px; color:rgba(255,255,255,.85);
  overflow:hidden;
  transition:transform .15s;
}
.news-item:hover .news-img{transform:translateY(-3px)}
.news-item.n1 .news-img{background:repeating-linear-gradient(135deg,#FFD0A0 0 16px,#FFAE57 16px 32px)}
.news-item.n2 .news-img{background:repeating-linear-gradient(135deg,#C7E5A8 0 16px,#9CD27A 16px 32px)}
.news-item.n3 .news-img{background:repeating-linear-gradient(135deg,#FFBED2 0 16px,#F47BA1 16px 32px)}
.news-date{font-size:11px; font-weight:700; color:var(--ink-soft); letter-spacing:.14em; text-transform:uppercase}
.news-item h3{font-size:22px; font-weight:700; margin:6px 0 8px; letter-spacing:-.015em}
.news-item p{margin:0 0 18px; color:var(--ink-soft); flex:1}


/* ============ CTA Tiles (Home page) ============ */
.tiles{
  padding:80px 0 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.tile{
  display:flex; align-items:center; justify-content:space-between;
  padding:26px 28px;
  border-radius:var(--r-lg);
  color:#fff;
  font-family:'Outfit'; font-weight:700;
  box-shadow:var(--shadow-sm);
  transition:transform .15s, box-shadow .15s;
  cursor:pointer;
  overflow:hidden; position:relative;
}
.tile:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.tile .text{display:flex; flex-direction:column; line-height:1.05; font-size:22px}
.tile .text .sub{font-size:12px; font-weight:600; opacity:.85; letter-spacing:.12em; text-transform:uppercase; margin-top:6px}
.tile .icon{
  width:54px; height:54px; border-radius:14px;
  background:rgba(255,255,255,.18);
  display:grid; place-items:center;
  border:2px solid rgba(255,255,255,.4);
}
.tile.mint{background:linear-gradient(135deg,#46B895,#2E8A6E)}
.tile.pink{background:linear-gradient(135deg,#E9628A,#C44C72)}
.tile.lav {background:linear-gradient(135deg,#8B78D0,#6552B5)}


/* ============ Switcher (Home page) ============ */
.v-switch{
  position:fixed; bottom:18px; right:18px;
  background:#FFFFFF;
  border:1px solid var(--line);
  border-radius:14px;
  padding:6px;
  box-shadow:var(--shadow-md);
  display:flex; gap:4px;
  font-family:'Outfit'; font-weight:700; font-size:12px;
  z-index:9999;
}
.v-switch .v-label{
  padding:8px 12px; color:var(--ink-soft);
  letter-spacing:.14em; text-transform:uppercase; font-size:10px;
  display:flex; align-items:center;
}
.v-switch a{
  padding:8px 14px; border-radius:9px;
  color:var(--ink);
  transition:background .15s, color .15s;
}
.v-switch a:hover{background:var(--sky-soft); color:var(--sky-deep)}
.v-switch a.on{background:var(--sky-deep); color:#fff}


/* ============ Info page: About + Stats ============ */
.about-grid{
  display:grid; grid-template-columns: 1.3fr 1fr; gap:40px; align-items:center;
}
.about-grid h2{font-size:36px; font-weight:800; letter-spacing:-.02em; margin-bottom:14px}
.about-grid p{color:var(--ink-soft); font-size:16px; margin:0 0 12px}
.about-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:28px}
.stat{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px;
}
.stat .num{font-family:'Outfit'; font-weight:800; font-size:32px; color:var(--sky-deep); line-height:1}
.stat .lab{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:6px}
.about-img{
  aspect-ratio: 4/3;
  border-radius:var(--r-lg);
  background:repeating-linear-gradient(135deg, #C9DEF0 0 18px, #A4BFD8 18px 36px);
  box-shadow:var(--shadow-md);
  display:grid; place-items:center;
  font-family:'JetBrains Mono', monospace; font-size:11px;
  color:rgba(255,255,255,.92); position:relative; overflow:hidden;
}
.about-img::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.18))}
.about-img span{position:relative; z-index:2; background:rgba(255,255,255,.92); color:#3A5570; padding:7px 12px; border-radius:6px}


/* ============ Info page: FAQ ============ */
.faq-list{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.faq{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:0; transition:border-color .12s, box-shadow .12s;
}
.faq:hover{border-color:#D5E1EC}
.faq summary{
  list-style:none; cursor:pointer;
  padding:18px 20px;
  display:flex; align-items:center; justify-content:space-between;
  font-family:'Outfit'; font-weight:700; font-size:15px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+"; font-size:22px; font-weight:300;
  color:var(--sky-deep); transition:transform .15s;
}
.faq[open] summary::after{content:"\2212"}
.faq[open]{box-shadow:var(--shadow-sm); border-color:var(--sky-soft)}
.faq .a{padding:0 20px 18px; color:var(--ink-soft); font-size:14.5px; line-height:1.65}


/* ============ Info page: Reviews ============ */
.reviews-row{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:24px; gap:24px;
}
.rev-meta{display:flex; align-items:center; gap:20px}
.rev-meta .big{font-family:'Outfit'; font-weight:800; font-size:54px; color:var(--ink); line-height:1; letter-spacing:-.025em}
.rev-meta .stars{display:flex; gap:2px; color:var(--sun)}
.rev-meta .sub{font-size:13px; color:var(--ink-soft); margin-top:4px; font-weight:700}
.rev-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.rev{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:22px 22px 20px;
}
.rev .stars{display:flex; gap:1px; color:var(--sun); margin-bottom:10px}
.rev .q{font-family:'Outfit'; font-weight:600; font-size:15.5px; color:var(--ink); margin:0 0 16px; line-height:1.5}
.rev .who{display:flex; align-items:center; gap:10px}
.rev .av{
  width:36px; height:36px; border-radius:50%;
  display:grid; place-items:center;
  font-family:'Outfit'; font-weight:800; font-size:13px;
  color:#fff;
}
.rev .av.a{background:linear-gradient(135deg,#F47BA1,#C44C72)}
.rev .av.b{background:linear-gradient(135deg,#46B895,#2E8A6E)}
.rev .av.c{background:linear-gradient(135deg,#7A66C4,#5544A0)}
.rev .nm{font-weight:800; font-size:13.5px}
.rev .when{font-size:11.5px; color:var(--ink-soft); font-weight:600}


/* ============ Info page: Contact ============ */
.contact-grid{display:grid; grid-template-columns:1.1fr 1fr; gap:32px; align-items:flex-start}
.form{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:28px;
}
.form .row{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-family:'Outfit'; font-weight:700; font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft)}
.field input, .field select, .field textarea{
  font-family:'Nunito'; font-size:14.5px; color:var(--ink);
  padding:12px 14px;
  border:1.5px solid var(--line); border-radius:11px;
  background:#fff; outline:none;
  transition:border-color .15s, box-shadow .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--sky); box-shadow:0 0 0 4px rgba(26,111,181,.12);
}
.field textarea{resize:vertical; min-height:110px; font-family:'Nunito'}
.form .btn{
  background:var(--coral); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:15px;
  padding:14px 22px; border-radius:11px;
  box-shadow:0 4px 0 var(--coral-deep), 0 8px 18px rgba(242,106,86,.35);
  transition:transform .12s;
}
.form .btn:hover{transform:translateY(-2px)}

.contact-info{display:flex; flex-direction:column; gap:14px}
.ci{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px; display:flex; gap:14px; align-items:flex-start;
}
.ci .ico{width:38px; height:38px; border-radius:10px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex-shrink:0}
.ci h4{font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:4px}
.ci p{margin:0; font-family:'Outfit'; font-weight:700; font-size:15.5px; line-height:1.4}
.ci p.sub{font-family:'Nunito'; font-weight:500; font-size:13.5px; color:var(--ink-soft); margin-top:3px}


/* ============ Info page: Careers (inline card) ============ */
.careers{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  border-radius:var(--r-lg); padding:48px;
  color:#fff; display:grid; grid-template-columns:1.3fr 1fr; gap:32px; align-items:center;
  position:relative; overflow:hidden;
}
.careers::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.14), transparent 50%), radial-gradient(circle at 5% 130%, rgba(255,255,255,.08), transparent 50%)}
.careers > *{position:relative}
.careers h2{color:#fff; font-size:36px; letter-spacing:-.02em}
.careers p{color:rgba(255,255,255,.85); margin:12px 0 24px; font-size:16px}
.careers .cta-row{display:flex; gap:12px; flex-wrap:wrap}
.careers .btn-prim{background:var(--coral); color:#fff; font-family:'Outfit'; font-weight:800; font-size:15px; padding:14px 22px; border-radius:11px; box-shadow:0 4px 0 var(--coral-deep), 0 8px 18px rgba(242,106,86,.35); transition:transform .12s}
.careers .btn-prim:hover{transform:translateY(-2px)}
.careers .btn-light{background:rgba(255,255,255,.14); color:#fff; border:1.5px solid rgba(255,255,255,.3); font-family:'Outfit'; font-weight:700; font-size:14px; padding:14px 20px; border-radius:11px}
.jobs{display:flex; flex-direction:column; gap:10px}
.job{
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r); padding:14px 18px;
  display:flex; align-items:center; gap:12px;
  transition:background .15s, transform .12s;
}
.job:hover{background:rgba(255,255,255,.15); transform:translateX(3px); cursor:pointer}
.job .ttl{flex:1; min-width:0; font-family:'Outfit'; font-weight:700; font-size:16px;}
.job .n{
  flex:none;
  background:rgba(255,255,255,.18);
  color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:12.5px;
  padding:4px 11px; border-radius:99px;
  white-space:nowrap;
}
.job .ar{flex:none; font-size:18px; opacity:.7}


/* ============ Info page: ADA (inline card) ============ */
.ada{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:32px 36px;
  display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:flex-start;
}
.ada .seal{
  width:84px; height:84px; border-radius:18px;
  background:var(--sky-soft); color:var(--sky-deep);
  display:grid; place-items:center;
}
.ada h3{font-size:22px; font-weight:800; margin-bottom:6px}
.ada p{margin:0 0 10px; color:var(--ink-soft); font-size:14.5px}
.ada .seal-row{display:flex; gap:10px; margin-top:14px; flex-wrap:wrap}
.seal-chip{
  background:var(--sky-soft); color:var(--sky-deep);
  padding:7px 12px; border-radius:999px;
  font-family:'Outfit'; font-weight:700; font-size:12px; letter-spacing:.06em;
}


/* ============ Programs page: Program tabs ============ */
.prog-tabs-band{
  background:#fff; border-bottom:1px solid var(--line);
  position:sticky; top:74px; z-index:90;
}
.prog-tabs{
  display:flex; gap:4px; padding:14px 0;
  overflow-x:auto;
}
.prog-tab{
  display:flex; align-items:center; gap:10px;
  padding:10px 18px;
  border-radius:11px;
  font-family:'Outfit'; font-weight:700; font-size:13.5px;
  color:var(--ink); cursor:pointer;
  transition:background .12s, color .12s;
  white-space:nowrap;
}
.prog-tab:hover{background:var(--sky-soft); color:var(--sky-deep)}
.prog-tab.on{background:var(--sky-deep); color:#fff; box-shadow:0 3px 0 var(--sky-darker)}
.prog-tab .dot{width:8px; height:8px; border-radius:50%; background:currentColor; opacity:.6}
.prog-tab .ag{font-size:11px; opacity:.75; letter-spacing:.06em; font-weight:600; margin-left:4px}


/* ============ Programs page: Hero ============ */
.prog-hero{
  background:
    radial-gradient(circle at 90% 10%, #DDEDF7 0%, transparent 50%),
    radial-gradient(circle at 0% 100%, #FFE8C1 0%, transparent 45%),
    linear-gradient(180deg, #F4F8FB 0%, #ECF3F8 100%);
  padding:48px 0 56px;
  position:relative;
}
.hero-row{
  display:grid; grid-template-columns: 1fr 1.2fr; gap:48px; align-items:center;
}
.age-chip{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--sun); color:#5A3B00;
  padding:8px 14px; border-radius:999px;
  font-family:'Outfit'; font-weight:800; font-size:12px; letter-spacing:.1em;
  text-transform:uppercase;
  box-shadow:0 3px 0 #D9A337;
}
.age-chip .dot{width:7px; height:7px; border-radius:50%; background:#5A3B00}
.hero-row h1{font-size:72px; line-height:.95; font-weight:800; margin:18px 0 16px; letter-spacing:-.025em}
.hero-row h1 .accent{color:var(--sky-deep)}

.quote{
  background:#fff; border-left:4px solid var(--coral);
  border-radius:0 var(--r) var(--r) 0;
  padding:22px 26px;
  font-family:'Outfit'; font-weight:600; font-style:italic;
  color:var(--ink); font-size:19px; line-height:1.45;
  box-shadow:var(--shadow-sm);
  margin:0 0 24px;
  max-width:48ch;
}
.hero-cta-row{display:flex; gap:14px; align-items:center; flex-wrap:wrap}


/* ============ Programs page: Facts band ============ */
.facts{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  margin-top:56px;
}
.fact{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px;
}
.fact .num{font-family:'Outfit'; font-weight:800; font-size:28px; color:var(--sky-deep); line-height:1}
.fact .lab{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:6px}


/* ============ Programs page: Content grid ============ */
.content-grid{
  display:grid; grid-template-columns: 1fr 320px; gap:56px;
  align-items:start;
}

.prose .block{margin-bottom:48px}
.prose .block:last-child{margin-bottom:0}
.prose .eyebrow{font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--sky); margin-bottom:6px}
.prose h2{font-size:32px; font-weight:800; letter-spacing:-.02em; margin-bottom:14px}
.prose p{font-size:16px; color:var(--ink); line-height:1.75; margin:0 0 14px}
.prose p strong{font-weight:800; color:var(--sky-deep)}

/* Curriculum grid */
.curr-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;
  margin-top:20px;
}
.curr{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px;
  transition:transform .15s, border-color .15s;
}
.curr:hover{transform:translateY(-2px); border-color:var(--sky)}
.curr .ic{width:32px; height:32px; border-radius:9px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; margin-bottom:10px}
.curr h4{font-size:14.5px; font-weight:800; margin-bottom:3px}
.curr p{font-size:13px; color:var(--ink-soft); margin:0; line-height:1.5}

/* Holiday strip */
.hol-strip{
  background:linear-gradient(135deg, #FFEFC4, #FFE0A8);
  border:1px solid #F4D097;
  border-radius:var(--r-lg);
  padding:26px 30px;
  margin-top:20px;
  display:grid; grid-template-columns:auto 1fr; gap:24px;
  align-items:center;
}
.hol-strip .ic-big{
  width:64px; height:64px; border-radius:16px;
  background:#fff; color:#A36608;
  display:grid; place-items:center;
  box-shadow:0 3px 0 #D9A337;
}
.hol-strip h3{color:#5A3B00; font-size:18px; font-weight:800; margin-bottom:4px}
.hol-strip p{margin:0; color:#7A5B27; font-size:14.5px}

/* Family days */
.family-days{
  margin-top:22px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
.fd{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 18px;
  text-align:center;
}
.fd .em{font-size:22px; margin-bottom:8px; color:var(--coral); font-family:'Outfit'; font-weight:800}
.fd h5{font-family:'Outfit'; font-weight:800; font-size:13px; margin-bottom:2px}
.fd p{margin:0; font-size:12px; color:var(--ink-soft); font-weight:600; letter-spacing:.04em}

/* Club KK card */
.club{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  color:#fff;
  border-radius:var(--r-lg);
  padding:36px 40px;
  margin-top:22px;
  position:relative; overflow:hidden;
}
.club::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.16), transparent 50%), radial-gradient(circle at 5% 130%, rgba(255,255,255,.08), transparent 50%)}
.club > *{position:relative}
.club h3{color:#fff; font-size:24px; font-weight:800; margin-bottom:10px}
.club p{color:rgba(255,255,255,.85); font-size:15px; max-width:60ch}
.club .stack-amen{
  display:flex; gap:8px; flex-wrap:wrap; margin-top:18px;
}
.club .stack-amen span{
  background:rgba(255,255,255,.14); color:#fff;
  border:1px solid rgba(255,255,255,.3);
  padding:8px 12px; border-radius:999px;
  font-family:'Outfit'; font-weight:700; font-size:12.5px;
}


/* ============ Programs page: Sidebar ============ */
.side{position:sticky; top:160px; display:flex; flex-direction:column; gap:18px}
.side-card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-sm)}
.side-card h4{font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px}
.side-card .item-row{display:flex; align-items:flex-start; gap:12px; padding:10px 0; border-bottom:1px solid var(--line)}
.side-card .item-row:last-child{border-bottom:0; padding-bottom:0}
.side-card .item-row .lab{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:2px}
.side-card .item-row .val{font-family:'Outfit'; font-weight:700; font-size:14.5px}
.side-card .item-row .ic{width:30px; height:30px; border-radius:9px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex-shrink:0}

.next-card{
  background:linear-gradient(135deg, var(--coral), var(--coral-deep));
  color:#fff;
  padding:24px; border-radius:var(--r-lg);
  box-shadow:0 6px 22px rgba(242,106,86,.4);
}
.next-card h4{color:rgba(255,255,255,.7); font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.22em; text-transform:uppercase; margin-bottom:10px}
.next-card h3{color:#fff; font-size:22px; font-weight:800; margin-bottom:6px; letter-spacing:-.01em}
.next-card p{color:rgba(255,255,255,.92); font-size:13.5px; margin:0 0 14px; line-height:1.5}
.next-card a{
  display:inline-flex; align-items:center; gap:6px;
  background:#fff; color:var(--coral-deep);
  padding:11px 18px; border-radius:11px;
  font-family:'Outfit'; font-weight:800; font-size:13.5px;
  box-shadow:0 3px 0 rgba(0,0,0,.08);
}


/* ============ Tour page ============ */
.tour{padding:48px 0 60px}
.tour-grid{
  display:grid;
  grid-template-columns: 1.35fr 1fr;
  gap:32px;
  align-items:flex-start;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.card-h{
  padding:20px 26px;
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}
.card-h .ttl{font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-deep)}
.step-dot{
  width:22px; height:22px; border-radius:50%;
  background:var(--sky-deep); color:#fff;
  display:inline-grid; place-items:center;
  font-family:'Outfit'; font-weight:800; font-size:12px;
  margin-right:8px;
}
.card-b{padding:26px}

/* Calendar */
.cal-h{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 26px;
  border-bottom:1px solid var(--line);
}
.cal-h h2{font-size:22px; font-weight:800; letter-spacing:-.015em}
.cal-h .month-nav{display:flex; gap:6px}
.cal-h .month-nav button{
  width:34px; height:34px; border-radius:10px;
  background:var(--sky-soft); color:var(--sky-deep);
  font-weight:800; font-size:18px;
  display:grid; place-items:center;
  transition:background .15s, color .15s;
}
.cal-h .month-nav button:hover{background:var(--sky); color:#fff}
.cal-h .today{
  font-family:'Outfit'; font-weight:700; font-size:12px;
  color:var(--sky-deep);
  padding:8px 12px; border-radius:9px;
  background:var(--sky-soft);
  transition:background .15s;
}
.cal-h .today:hover{background:var(--sky); color:#fff}

.cal-body{padding:18px 26px 26px}
.cal-weekrow{
  display:grid; grid-template-columns:repeat(7,1fr); gap:6px;
  margin-bottom:8px;
}
.cal-weekrow span{
  text-align:center; font-family:'Outfit';
  font-weight:800; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); padding:6px 0;
}
.cal-grid{
  display:grid; grid-template-columns:repeat(7,1fr); gap:6px;
}
.cal-day{
  aspect-ratio:1/1;
  border-radius:10px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-family:'Outfit';
  font-weight:600;
  font-size:28px;
  color:var(--ink);
  background:transparent;
  transition:background .12s, color .12s, transform .12s;
  cursor:pointer; position:relative;
}
.cal-day:hover:not(.muted):not(.past):not(.closed){
  background:var(--sky-soft); color:var(--sky-deep);
}
.cal-day.muted{color:#C8D4DE; cursor:default}
.cal-day.past{color:#C8D4DE; cursor:not-allowed; text-decoration:line-through; text-decoration-color:#D8E1EA}
.cal-day.closed{color:#C8D4DE; cursor:not-allowed; background:repeating-linear-gradient(135deg,#F4F8FB 0 6px,#EEF3F8 6px 12px)}
.cal-day .av-dot{
  width:5px; height:5px; border-radius:50%;
  background:var(--mint); margin-top:3px;
}
.cal-day.busy .av-dot{background:var(--sun)}
.cal-day.today{box-shadow:inset 0 0 0 2px var(--sky); color:var(--sky-deep)}
.cal-day.selected{
  background:var(--sky-deep); color:#fff;
  box-shadow:0 4px 12px rgba(11,79,134,.25);
}
.cal-day.selected .av-dot{background:#fff}

.cal-legend{
  display:flex; gap:18px; align-items:center; flex-wrap:wrap;
  margin-top:18px; padding-top:18px;
  border-top:1px solid var(--line);
  font-size:12px; color:var(--ink-soft);
}
.cal-legend .lg{display:flex; align-items:center; gap:6px; font-weight:700}
.cal-legend .lg .sw{width:10px; height:10px; border-radius:50%}
.lg.open .sw{background:var(--mint)}
.lg.busy .sw{background:var(--sun)}
.lg.closed .sw{background:repeating-linear-gradient(135deg,#F4F8FB 0 3px,#DCE5ED 3px 6px)}
.lg.sel .sw{background:var(--sky-deep)}

/* Time slots */
.slots-h{
  padding:18px 26px;
  border-top:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}
.slots-h h3{font-size:15px; font-weight:800; letter-spacing:-.005em}
.slots-h .sub{font-size:12px; color:var(--ink-soft); font-weight:700}
.slots{
  display:grid; grid-template-columns:repeat(4,1fr); gap:10px;
  padding:6px 26px 26px;
}
.slot{
  padding:12px 14px; border-radius:11px;
  border:1.5px solid var(--line);
  background:#fff; color:var(--ink);
  font-family:'Outfit'; font-weight:700; font-size:13.5px;
  text-align:center;
  transition:border-color .15s, background .15s, color .15s, transform .12s;
}
.slot:hover:not(.unav):not(.selected){border-color:var(--sky); color:var(--sky-deep); transform:translateY(-1px)}
.slot.selected{
  background:var(--sky-deep); color:#fff;
  border-color:var(--sky-deep);
  box-shadow:0 4px 12px rgba(11,79,134,.25);
}
.slot.unav{color:#C0CCD7; background:var(--bg); cursor:not-allowed; text-decoration:line-through; text-decoration-color:#D8E1EA}

/* School picker */
.sp-search{
  display:flex; align-items:center; gap:10px;
  background:var(--bg); border:1px solid var(--line);
  border-radius:11px; padding:10px 14px;
  margin-bottom:14px;
}
.sp-search input{
  flex:1; border:0; background:transparent; outline:0;
  font-family:'Nunito'; font-size:14px; color:var(--ink);
}
.sp-search svg{color:var(--ink-soft)}

.region{margin-bottom:14px}
.region:last-child{margin-bottom:0}
.region h5{
  font-size:11px; font-weight:800; letter-spacing:.22em;
  text-transform:uppercase; color:var(--sky-deep);
  margin:0 0 10px; display:flex; align-items:center; justify-content:space-between;
}
.region h5 .ct{
  background:var(--sky-soft); color:var(--sky-deep);
  padding:2px 8px; border-radius:999px;
  font-size:10px; letter-spacing:.06em;
}
.sp-list{display:flex; flex-direction:column; gap:4px}
.sp-item{
  display:flex; align-items:center; gap:12px;
  padding:11px 12px; border-radius:11px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:background .12s, border-color .12s, transform .12s;
}
.sp-item:hover{background:var(--sky-soft)}
.sp-item.selected{
  background:var(--sky-soft);
  border-color:var(--sky);
}
.sp-item .mk{
  width:9px; height:9px; border-radius:50%;
  background:var(--coral); flex-shrink:0;
}
.sp-list.clovis .sp-item .mk{background:var(--sky)}
.sp-list.madera .sp-item .mk{background:var(--lavender)}
.sp-item .nm{font-weight:700; font-size:14px; color:var(--ink); flex:1}
.sp-item .ad{font-size:11.5px; color:var(--ink-soft); font-weight:600; letter-spacing:.02em}
.sp-item .chk{
  width:20px; height:20px; border-radius:50%;
  border:1.5px solid #D5DEE7;
  display:grid; place-items:center;
  color:#fff; flex-shrink:0;
}
.sp-item.selected .chk{background:var(--sky-deep); border-color:var(--sky-deep)}
.sp-item.selected .chk::after{
  content:""; width:7px; height:4px;
  border-left:2px solid #fff; border-bottom:2px solid #fff;
  transform:rotate(-45deg) translateY(-1px);
}

/* Summary / Confirm */
.summary{
  margin-top:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:22px 24px;
  box-shadow:var(--shadow-sm);
}
.summary h4{
  font-size:11px; font-weight:800; letter-spacing:.22em;
  text-transform:uppercase; color:var(--sky-deep);
  margin:0 0 14px;
}
.sm-rows{display:flex; flex-direction:column; gap:10px; margin-bottom:18px}
.sm-row{
  display:flex; align-items:center; gap:12px;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
}
.sm-row:last-child{border-bottom:0}
.sm-row .ico{
  width:32px; height:32px; border-radius:9px;
  background:var(--sky-soft); color:var(--sky-deep);
  display:grid; place-items:center; flex-shrink:0;
}
.sm-row .lab{font-size:11px; color:var(--ink-soft); font-weight:700; letter-spacing:.1em; text-transform:uppercase}
.sm-row .val{font-family:'Outfit'; font-weight:700; font-size:15px; color:var(--ink); margin-top:1px}
.sm-row .val.empty{color:#B5C2CD; font-weight:600}
.sm-cta{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
}

/* Helpful info row */
.help-row{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
  margin-top:34px;
}
.help-card{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r);
  padding:18px 20px;
  display:flex; gap:14px; align-items:flex-start;
}
.help-card .ico{
  width:38px; height:38px; border-radius:10px;
  background:var(--sky-soft); color:var(--sky-deep);
  display:grid; place-items:center; flex-shrink:0;
}
.help-card h6{font-family:'Outfit'; font-weight:800; font-size:14px; margin:0 0 4px}
.help-card p{margin:0; color:var(--ink-soft); font-size:13px; line-height:1.5}


/* ============ Blog page ============ */
.head-row{display:flex; align-items:flex-end; justify-content:space-between; gap:32px}

/* Search bar */
.search-row{
  display:flex; align-items:center; gap:10px;
  background:#fff; border:1px solid var(--line);
  border-radius:14px; padding:10px 14px;
  box-shadow:var(--shadow-sm);
  min-width:340px;
}
.search-row input{flex:1; border:0; background:transparent; outline:0; font-family:'Nunito'; font-size:14px; color:var(--ink)}

/* Category chips */
.cats{
  display:flex; gap:8px; flex-wrap:wrap;
  margin-top:36px;
}
.cat{
  padding:9px 16px; border-radius:999px;
  background:#fff; border:1.5px solid var(--line);
  font-family:'Outfit'; font-weight:700; font-size:13px; color:var(--ink-soft);
  transition:border-color .12s, color .12s, background .12s;
}
.cat:hover{border-color:var(--sky); color:var(--sky-deep)}
.cat.on{background:var(--sky-deep); border-color:var(--sky-deep); color:#fff}
.cat .ct{margin-left:6px; opacity:.7; font-size:11.5px; font-weight:600}

/* Featured post */
.featured{padding:48px 0 0}
.feat-card{
  display:grid; grid-template-columns: 1.1fr 1fr;
  gap:0; align-items:stretch;
  background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-md);
}
.feat-img{
  background:repeating-linear-gradient(135deg, #FFD0A0 0 18px, #FFAE57 18px 36px);
  display:grid; place-items:center; position:relative; min-height:360px;
}
.feat-img::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.2))}
.feat-img .lbl{position:relative; z-index:2; background:rgba(255,255,255,.92); color:#7A5418; padding:7px 12px; border-radius:6px; font-family:'JetBrains Mono', monospace; font-size:11px}
.feat-tag{
  position:absolute; top:18px; left:18px; z-index:2;
  background:var(--coral); color:#fff;
  padding:6px 12px; border-radius:999px;
  font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
}
.feat-body{padding:36px 40px; display:flex; flex-direction:column; justify-content:center}
.feat-meta{display:flex; gap:10px; align-items:center; font-family:'Outfit'; font-weight:700; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px}
.feat-meta .dot{width:4px; height:4px; border-radius:50%; background:var(--ink-soft)}
.feat-body h2{font-size:34px; font-weight:800; letter-spacing:-.02em; line-height:1.1; margin-bottom:14px}
.feat-body p{color:var(--ink-soft); font-size:16px; margin:0 0 22px; max-width:48ch}
.feat-author{display:flex; align-items:center; gap:12px; margin-bottom:20px}
.feat-author .av{
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,#46B895,#2E8A6E);
  color:#fff; display:grid; place-items:center;
  font-family:'Outfit'; font-weight:800; font-size:14px;
}
.feat-author .nm{font-weight:800; font-size:14px}
.feat-author .ro{font-size:12px; color:var(--ink-soft); font-weight:600}
.read-btn{
  align-self:flex-start;
  background:var(--coral); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:14px;
  padding:12px 20px; border-radius:11px;
  box-shadow:0 4px 0 var(--coral-deep), 0 8px 18px rgba(242,106,86,.35);
  transition:transform .12s;
}
.read-btn:hover{transform:translateY(-2px)}

/* Posts grid */
.posts{padding:64px 0 0}
.sort{
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--ink-soft); font-weight:700;
}
.sort select{
  border:1.5px solid var(--line); border-radius:9px;
  padding:7px 10px; font-family:'Outfit'; font-weight:700; font-size:13px;
  color:var(--ink); background:#fff; outline:0;
}

.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px}
.post{display:flex; flex-direction:column; cursor:pointer; transition:transform .15s}
.post:hover{transform:translateY(-3px)}
.post-img{
  aspect-ratio: 4/3;
  border-radius:var(--r-lg); margin-bottom:18px;
  position:relative; overflow:hidden;
  display:grid; place-items:center;
  font-family:'JetBrains Mono', monospace; font-size:11px; color:rgba(255,255,255,.85);
}
.post-img.p1{background:repeating-linear-gradient(135deg,#F4C9D7 0 16px,#E199B0 16px 32px)}
.post-img.p2{background:repeating-linear-gradient(135deg,#B5DDD2 0 16px,#7AC3B3 16px 32px)}
.post-img.p3{background:repeating-linear-gradient(135deg,#BFDEF1 0 16px,#83B7DC 16px 32px)}
.post-img.p4{background:repeating-linear-gradient(135deg,#FFD0A0 0 16px,#FFAE57 16px 32px)}
.post-img.p5{background:repeating-linear-gradient(135deg,#E1D2F2 0 16px,#B79CDC 16px 32px)}
.post-img.p6{background:repeating-linear-gradient(135deg,#F8C5B0 0 16px,#E59E83 16px 32px)}
.post-img.p7{background:repeating-linear-gradient(135deg,#FFE0A8 0 16px,#FFB454 16px 32px)}
.post-img.p8{background:repeating-linear-gradient(135deg,#C7E5A8 0 16px,#9CD27A 16px 32px)}
.post-img.p9{background:repeating-linear-gradient(135deg,#D5C7E8 0 16px,#B19EDE 16px 32px)}
.pill-tag{
  position:absolute; top:14px; left:14px;
  background:rgba(255,255,255,.95); color:var(--sky-deep);
  padding:5px 10px; border-radius:999px;
  font-family:'Outfit'; font-weight:800; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase;
}
.post-meta{display:flex; gap:10px; align-items:center; font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px}
.post-meta .dot{width:3px; height:3px; border-radius:50%; background:var(--ink-soft)}
.post h3{font-size:21px; font-weight:700; margin:0 0 8px; letter-spacing:-.015em; line-height:1.25}
.post p{margin:0 0 14px; color:var(--ink-soft); font-size:14.5px; flex:1; line-height:1.55}
.post-foot{
  display:flex; align-items:center; gap:10px;
  padding-top:14px; border-top:1px solid var(--line);
}
.post-foot .av{width:28px; height:28px; border-radius:50%; display:grid; place-items:center; color:#fff; font-family:'Outfit'; font-weight:800; font-size:11px}
.post-foot .av.a{background:linear-gradient(135deg,#F47BA1,#C44C72)}
.post-foot .av.b{background:linear-gradient(135deg,#46B895,#2E8A6E)}
.post-foot .av.c{background:linear-gradient(135deg,#7A66C4,#5544A0)}
.post-foot .av.d{background:linear-gradient(135deg,#1F7DC8,#0B4F86)}
.post-foot .nm{font-size:12.5px; font-weight:700; color:var(--ink)}
.post-foot .rd{font-size:11.5px; color:var(--ink-soft); font-weight:600; margin-left:auto}

/* Pagination */
.pag{display:flex; justify-content:center; align-items:center; gap:8px; margin-top:48px}
.pag a, .pag span{
  min-width:38px; height:38px; padding:0 12px; border-radius:10px;
  display:inline-grid; place-items:center;
  font-family:'Outfit'; font-weight:700; font-size:14px;
  background:#fff; border:1px solid var(--line); color:var(--ink);
  transition:background .12s, color .12s, border-color .12s;
}
.pag a:hover{background:var(--sky-soft); color:var(--sky-deep); border-color:var(--sky-soft)}
.pag a.on{background:var(--sky-deep); color:#fff; border-color:var(--sky-deep)}
.pag .arr{font-size:18px}

/* Newsletter */
.newsletter{
  margin-top:80px;
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  border-radius:var(--r-lg); padding:48px;
  color:#fff;
  display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:center;
  position:relative; overflow:hidden;
}
.newsletter::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.14), transparent 50%), radial-gradient(circle at 5% 130%, rgba(255,255,255,.08), transparent 50%)}
.newsletter > *{position:relative}
.newsletter h2{color:#fff; font-size:32px; letter-spacing:-.02em}
.newsletter p{color:rgba(255,255,255,.85); margin:10px 0 0; font-size:15.5px}
.nl-form{
  display:flex; gap:10px;
  background:rgba(255,255,255,.14);
  border:1.5px solid rgba(255,255,255,.3);
  padding:6px; border-radius:14px;
}
.nl-form input{
  flex:1; border:0; background:transparent; outline:0;
  color:#fff; font-family:'Nunito'; font-size:14.5px;
  padding:10px 14px;
}
.nl-form input::placeholder{color:rgba(255,255,255,.65)}
.nl-form button{
  background:var(--coral); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:14px;
  padding:11px 22px; border-radius:10px;
  box-shadow:0 3px 0 var(--coral-deep);
}


/* ============ Recent News page ============ */
.news-wrap{display:grid; grid-template-columns: 1fr 280px; gap:48px; align-items:start}

/* Filters rail */
.rail{position:sticky; top:96px; display:flex; flex-direction:column; gap:24px}
.rail h4{font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:12px}
.rail-card{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:18px 20px}
.year-list{display:flex; flex-direction:column; gap:2px}
.year-link{
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 10px; border-radius:9px;
  font-family:'Outfit'; font-weight:700; font-size:14px;
  color:var(--ink); cursor:pointer;
  transition:background .12s, color .12s;
}
.year-link:hover{background:var(--sky-soft); color:var(--sky-deep)}
.year-link.on{background:var(--sky-deep); color:#fff}
.year-link .ct{font-size:11px; opacity:.8; font-weight:700}
.rail-card.sub{background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker)); color:#fff; padding:22px}
.rail-card.sub h4{color:rgba(255,255,255,.7)}
.rail-card.sub p{margin:0 0 14px; font-size:13.5px; color:rgba(255,255,255,.9); line-height:1.55}
.rail-card.sub .sub-form{display:flex; gap:6px}
.rail-card.sub input{flex:1; min-width:0; padding:10px 12px; border-radius:9px; border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.1); color:#fff; font-family:'Nunito'; font-size:13px; outline:none}
.rail-card.sub input::placeholder{color:rgba(255,255,255,.6)}
.rail-card.sub input:focus{border-color:#fff; background:rgba(255,255,255,.15)}
.rail-card.sub button{background:var(--coral); color:#fff; font-family:'Outfit'; font-weight:800; font-size:12px; padding:0 14px; border-radius:9px; box-shadow:0 3px 0 var(--coral-deep)}

/* News feed */
.feed{display:flex; flex-direction:column; gap:0}
.year-band{
  font-family:'Outfit'; font-weight:800; font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--sky); margin:32px 0 12px;
  display:flex; align-items:center; gap:14px;
}
.year-band:first-child{margin-top:0}
.year-band::after{content:""; flex:1; height:1px; background:var(--line)}
.item{
  display:grid; grid-template-columns: 120px 1fr;
  gap:28px;
  padding:24px 0;
  border-bottom:1px solid var(--line);
  align-items:flex-start;
}
.item .when{
  background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:14px 10px;
  text-align:center;
  box-shadow:var(--shadow-sm);
  width:120px;
}
.item .when .mo{font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--coral)}
.item .when .da{font-family:'Outfit'; font-weight:800; font-size:34px; color:var(--ink); line-height:1; margin:3px 0 2px}
.item .when .yr{font-family:'Outfit'; font-weight:700; font-size:12px; color:var(--ink-soft); letter-spacing:.1em}
.item .post h3{font-size:24px; font-weight:800; letter-spacing:-.015em; margin-bottom:6px}
.item .post p{margin:0 0 14px; color:var(--ink-soft); font-size:15.5px; max-width:60ch}
.item .post .tag-row{display:flex; align-items:center; gap:10px; margin-bottom:10px}
.item .post .tag{
  background:var(--sky-soft); color:var(--sky-deep);
  padding:4px 10px; border-radius:999px;
  font-family:'Outfit'; font-weight:800; font-size:10.5px;
  letter-spacing:.1em; text-transform:uppercase;
}
.item .post .tag.holiday{background:#FEE5DD; color:#C73E2A}
.item .post .tag.event{background:#E8E0F7; color:#5A47A6}
.item .post .tag.season{background:#DEF1E7; color:#1E7A4C}
.item .post .tag.community{background:#FFEFC4; color:#8A6315}
.item .post .read-more{
  color:var(--sky-deep); font-family:'Outfit'; font-weight:800; font-size:13px;
  border-bottom:2px solid var(--sky); padding-bottom:2px;
}
.item .post .read-more:hover{color:var(--coral); border-color:var(--coral)}


/* ============ Careers page ============ */
.mission{
  display:grid; grid-template-columns: 1fr 1fr; gap:40px;
  align-items:center;
  margin-bottom:64px;
}
.mission-img{
  aspect-ratio: 4/3;
  border-radius:var(--r-lg);
  background:repeating-linear-gradient(135deg, #BFDEF1 0 18px, #83B7DC 18px 36px);
  box-shadow:var(--shadow-md);
  display:grid; place-items:center;
  position:relative; overflow:hidden;
}
.mission-img::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.18))}
.mission-img span{position:relative; z-index:2; background:rgba(255,255,255,.92); color:#3A5570; padding:7px 12px; border-radius:6px; font-family:'JetBrains Mono', monospace; font-size:11px}

.mission h2{font-size:34px; font-weight:800; letter-spacing:-.02em; margin-bottom:16px}
.mission p{color:var(--ink-soft); font-size:16px; margin:0 0 10px}

/* Positions */
.positions{margin-bottom:64px}
.pos-head{margin-bottom:28px}
.pos-head h2{font-size:34px; font-weight:800; letter-spacing:-.02em}
.pos-head p{color:var(--ink-soft); margin:10px 0 0; font-size:16px; max-width:64ch}
.pos-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.pos-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:28px 26px 26px;
  display:flex; flex-direction:column;
  transition:transform .15s, border-color .15s, box-shadow .15s;
  position:relative; overflow:hidden;
}
.pos-card:hover{transform:translateY(-3px); border-color:var(--sky); box-shadow:var(--shadow-md)}
.pos-card .stripe{
  position:absolute; top:0; left:0; right:0; height:4px;
}
.pos-card.t1 .stripe{background:var(--coral)}
.pos-card.t2 .stripe{background:var(--lavender)}
.pos-card.t3 .stripe{background:var(--mint)}
.pos-card .ico{
  width:48px; height:48px; border-radius:13px;
  display:grid; place-items:center; color:#fff;
  margin-bottom:18px;
}
.pos-card.t1 .ico{background:linear-gradient(135deg,#F47B68,#D64A36)}
.pos-card.t2 .ico{background:linear-gradient(135deg,#8B78D0,#6552B5)}
.pos-card.t3 .ico{background:linear-gradient(135deg,#46B895,#2E8A6E)}
.pos-card h3{font-size:26px; font-weight:800; color:var(--sky-deep); margin:0 0 12px; letter-spacing:-.01em; line-height:1.15}
.pos-card .who{font-family:'Nunito'; color:var(--ink); font-size:14.5px; line-height:1.55; margin:0 0 18px; flex:1}
.pos-card .roles-h{
  font-family:'Outfit'; font-weight:800; font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft);
  margin:0 0 8px;
}
.pos-card .roles{
  list-style:none; padding:0; margin:0 0 18px;
  display:flex; flex-direction:column; gap:2px;
}
.pos-card .roles li{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:6px 0;
  border-bottom:1px solid var(--line-soft);
  font-family:'Outfit'; font-weight:700; font-size:14px; color:var(--ink);
}
.pos-card .roles li:last-child{ border-bottom:none; }
.pos-card .roles .role-nm{ min-width:0; }
.pos-card .roles .role-n{
  flex:none; min-width:24px; text-align:center;
  background:var(--sky-soft); color:var(--sky-deep);
  font-family:'Outfit'; font-weight:800; font-size:12.5px;
  padding:2px 8px; border-radius:999px;
}
.pos-card .learn{
  color:var(--sky-deep); font-family:'Outfit'; font-weight:800; font-size:12.5px;
  letter-spacing:.1em; text-transform:uppercase;
  border-top:1px solid var(--line); padding-top:14px;
  display:flex; align-items:center; justify-content:space-between;
}
.pos-card .learn .ar{font-size:18px}

/* Requirements + CTA */
.reqs-band{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:40px;
  margin-bottom:64px;
}
.reqs{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:36px 36px;
}
.reqs h2{font-size:24px; font-weight:800; margin-bottom:6px}
.reqs .sub{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:22px}
.reqs ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px}
.reqs li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:15px; color:var(--ink); line-height:1.5;
}
.reqs li .check{
  flex-shrink:0;
  width:26px; height:26px; border-radius:50%;
  background:var(--sky-soft); color:var(--sky-deep);
  display:grid; place-items:center;
  margin-top:1px;
}

/* Join CTA */
.join-cta{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  border-radius:var(--r-lg); padding:40px;
  color:#fff; display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden;
}
.join-cta::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.16), transparent 50%), radial-gradient(circle at 5% 130%, rgba(255,255,255,.1), transparent 50%)}
.join-cta > *{position:relative}
.join-cta .eyebrow{color:rgba(255,255,255,.7)}
.join-cta h2{color:#fff; font-size:30px; letter-spacing:-.02em; line-height:1.1; margin-bottom:14px}
.join-cta p{color:rgba(255,255,255,.85); margin:0 0 22px; font-size:15.5px}
.join-row{display:flex; gap:12px; flex-wrap:wrap}

/* Benefits strip */
.benefits{margin-bottom:64px}
.ben-head{margin-bottom:24px}
.ben-head h2{font-size:28px; font-weight:800; letter-spacing:-.02em}
.ben-head p{color:var(--ink-soft); margin:8px 0 0; font-size:15.5px}
.ben-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.ben{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:22px;
}
.ben .ico{
  width:38px; height:38px; border-radius:10px;
  background:var(--sky-soft); color:var(--sky-deep);
  display:grid; place-items:center; margin-bottom:14px;
}
.ben h4{font-size:15px; font-weight:800; margin-bottom:4px}
.ben p{margin:0; font-size:13.5px; color:var(--ink-soft); line-height:1.5}


/* ============ ADA page ============ */
.head-inner{display:grid; grid-template-columns: 1fr auto; gap:28px; align-items:flex-end}
.seal{
  width:120px; height:120px; border-radius:22px;
  background:linear-gradient(135deg, #fff, #EAF2F9);
  border:1px solid var(--line);
  display:grid; place-items:center;
  box-shadow:var(--shadow-md);
  color:var(--sky-deep);
}
.ada-grid{display:grid; grid-template-columns: 1fr 300px; gap:56px; align-items:start}

.stack{display:flex; flex-direction:column; gap:24px}
.policy{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:28px 32px 26px;
  box-shadow:var(--shadow-sm);
  position:relative;
}
.policy .num{
  position:absolute; top:-12px; left:24px;
  background:var(--sky-deep); color:#fff;
  width:32px; height:32px; border-radius:9px;
  display:grid; place-items:center;
  font-family:'Outfit'; font-weight:800; font-size:13px;
  box-shadow:0 3px 0 var(--sky-darker), 0 6px 14px rgba(11,79,134,.25);
}
.policy h3{
  font-size:15px; font-weight:800;
  color:var(--sky-deep); letter-spacing:.14em; text-transform:uppercase;
  margin:6px 0 14px;
}
.policy p{
  margin:0 0 12px;
  font-size:15.5px; color:var(--ink);
  line-height:1.7;
}
.policy p:last-child{margin-bottom:0}
.policy em{font-style:italic; color:var(--ink-soft)}

/* Highlighted term */
.term{
  display:inline;
  background:linear-gradient(180deg, transparent 55%, rgba(242,106,86,.20) 55%);
  color:var(--coral-deep);
  font-weight:800;
  cursor:pointer;
  padding:0 2px;
  border-radius:3px;
  transition:background .15s, color .15s;
  position:relative;
}
.term:hover{
  background:linear-gradient(180deg, transparent 0%, rgba(242,106,86,.28) 0%);
  color:var(--coral-deep);
}
.term::after{
  content:"\24D8";
  font-family:'Outfit'; font-weight:600;
  font-size:.85em;
  margin-left:3px;
  color:var(--coral);
  opacity:.85;
}

/* Underlined "not" */
.neg{text-decoration:underline; text-underline-offset:3px; font-weight:800; color:var(--coral-deep)}

/* USDA link box */
.link-box{
  margin-top:16px;
  background:var(--sky-soft); border:1px solid #C9DCEB;
  border-radius:var(--r); padding:14px 18px;
  display:flex; align-items:center; gap:14px;
  word-break:break-all;
}
.link-box .ico{width:36px; height:36px; border-radius:9px; background:#fff; color:var(--sky-deep); display:grid; place-items:center; flex-shrink:0}
.link-box a{color:var(--sky-deep); font-family:'JetBrains Mono', monospace; font-size:13.5px; font-weight:600; text-decoration:underline}

/* EO provider */
.eo{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  color:#fff;
  border-radius:var(--r-lg);
  padding:28px 32px;
  display:flex; align-items:center; gap:20px;
  box-shadow:var(--shadow-md);
  position:relative; overflow:hidden;
}
.eo::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.16), transparent 50%)}
.eo > *{position:relative}
.eo .ic{
  width:54px; height:54px; border-radius:14px;
  background:rgba(255,255,255,.18);
  border:1.5px solid rgba(255,255,255,.4);
  display:grid; place-items:center; flex-shrink:0;
}
.eo .lbl{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.75); margin-bottom:2px}
.eo h3{color:#fff; font-size:22px; font-weight:800; letter-spacing:-.015em}

/* ADA sidebar */
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{
  background:var(--sky-soft); color:var(--sky-deep);
  padding:7px 12px; border-radius:999px;
  font-family:'Outfit'; font-weight:700; font-size:12px; letter-spacing:.04em;
}

.gloss-list{display:flex; flex-direction:column; gap:4px}
.gloss-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-radius:10px;
  font-family:'Outfit'; font-weight:700; font-size:14px;
  color:var(--ink); cursor:pointer;
  transition:background .12s, color .12s;
}
.gloss-row:hover{background:var(--sky-soft); color:var(--sky-deep)}
.gloss-row .ab{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  color:var(--ink-soft); font-weight:500;
}
.gloss-row .ico-q{
  width:22px; height:22px; border-radius:6px;
  background:var(--line-soft);
  display:grid; place-items:center;
  color:var(--sky-deep); font-family:'Outfit'; font-weight:800; font-size:12px;
}

.contact-card{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  color:#fff;
  padding:22px;
  border-radius:var(--r-lg);
  position:relative; overflow:hidden;
}
.contact-card::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 95% -20%, rgba(255,255,255,.16), transparent 50%)}
.contact-card > *{position:relative}
.contact-card h4{color:rgba(255,255,255,.7); font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.22em; text-transform:uppercase; margin-bottom:10px}
.contact-card h3{color:#fff; font-size:18px; font-weight:800; margin-bottom:6px}
.contact-card p{color:rgba(255,255,255,.85); font-size:13.5px; margin:0 0 14px}
.contact-card a{
  display:inline-block;
  background:var(--coral); color:#fff;
  padding:11px 16px; border-radius:11px;
  font-family:'Outfit'; font-weight:800; font-size:13px;
  box-shadow:0 3px 0 var(--coral-deep);
}


/* ============ ADA page: Drawer ============ */
.drawer-scrim{
  position:fixed; inset:0;
  background:rgba(11,42,69,.45);
  opacity:0; pointer-events:none;
  transition:opacity .25s ease;
  z-index:200;
}
.drawer-scrim.open{opacity:1; pointer-events:auto}
.drawer{
  position:fixed; top:0; right:0; bottom:0;
  width:480px; max-width:92vw;
  background:#fff;
  box-shadow:-12px 0 40px -10px rgba(11,42,69,.25);
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
  z-index:201;
  display:flex; flex-direction:column;
}
.drawer.open{transform:translateX(0)}

.drawer-band{
  background:linear-gradient(135deg, var(--sky-deep), var(--sky-darker));
  color:#fff;
  padding:26px 28px 24px;
  position:relative; overflow:hidden;
}
.drawer-band::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 100% 0%, rgba(255,255,255,.18), transparent 50%), radial-gradient(circle at 0% 100%, rgba(242,106,86,.4), transparent 55%)}
.drawer-band > *{position:relative}
.drawer-eyebrow{
  font-family:'Outfit'; font-weight:800; font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
  display:flex; align-items:center; gap:8px;
}
.drawer-eyebrow .icon{
  width:20px; height:20px; border-radius:6px;
  background:rgba(255,255,255,.18);
  display:grid; place-items:center;
}
.drawer h2{
  color:#fff; font-size:30px; font-weight:800; margin:10px 0 4px;
  letter-spacing:-.02em; line-height:1.1;
}
.drawer .abbr{
  color:rgba(255,255,255,.85);
  font-family:'JetBrains Mono', monospace; font-size:13px;
  font-weight:500;
}
.drawer-close{
  position:absolute; top:16px; right:16px;
  width:36px; height:36px; border-radius:10px;
  background:rgba(255,255,255,.16); color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  display:grid; place-items:center;
  transition:background .15s;
  z-index:2;
}
.drawer-close:hover{background:rgba(255,255,255,.28)}
.drawer-body{
  padding:24px 28px 28px;
  overflow-y:auto;
  flex:1;
}
.drawer-body h3{font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky); margin:18px 0 8px; font-weight:800}
.drawer-body h3:first-child{margin-top:0}
.drawer-body p{font-size:15px; color:var(--ink); line-height:1.65; margin:0 0 12px}
.drawer-body .what{
  background:var(--sky-soft);
  border-left:3px solid var(--sky);
  padding:14px 16px; border-radius:0 10px 10px 0;
  color:var(--ink); font-size:15px; line-height:1.6;
}
.drawer-body ul{margin:0; padding-left:22px; color:var(--ink); font-size:14.5px; line-height:1.65}
.drawer-body ul li{margin-bottom:5px}
.drawer-foot{
  padding:18px 28px;
  border-top:1px solid var(--line);
  background:var(--bg);
  display:flex; gap:10px; align-items:center; justify-content:space-between;
  font-size:12px; color:var(--ink-soft);
}
.drawer-foot a{
  color:var(--sky-deep); font-weight:800;
  font-family:'Outfit'; font-size:12.5px;
  border-bottom:2px solid var(--sky); padding-bottom:1px;
}
.drawer-foot .pill-rail{
  background:#fff; border:1px solid var(--line); padding:5px 10px; border-radius:999px;
  display:flex; align-items:center; gap:6px;
  font-family:'JetBrains Mono', monospace; font-size:11px;
}
.drawer-foot .pill-rail b{color:var(--ink); font-family:'Outfit'; font-weight:800}


/* ============ Footer ============ */
.footer{
  margin-top:80px;
  background:linear-gradient(180deg, var(--sky-deep) 0%, var(--sky-darker) 100%);
  color:#fff;
  padding:56px 0 28px;
  position:relative; overflow:hidden;
}
.footer::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 95% -20%, rgba(255,255,255,.14), transparent 50%),
    radial-gradient(circle at 5% 130%, rgba(255,255,255,.08), transparent 50%);
}
.footer-grid{position:relative; display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:48px; align-items:start}
.footer .brand-text .wm{color:#fff}
.footer .brand-text .tg{color:rgba(255,255,255,.8)}
.foot-col h5{
  font-family:'Outfit'; font-weight:700; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase;
  margin-bottom:14px; color:#fff;
}
.foot-col p{margin:2px 0; font-size:14px; color:rgba(255,255,255,.9); line-height:1.7}
.foot-col p.big{font-size:18px; font-weight:700; color:#fff; margin-top:6px}
.socials{display:flex; gap:10px; margin-top:14px}
.socials a{
  width:38px; height:38px; border-radius:10px;
  background:rgba(255,255,255,.16);
  border:1.5px solid rgba(255,255,255,.4);
  display:grid; place-items:center;
  transition:background .15s, color .15s;
  color:#fff;
}
.socials a:hover{background:#fff; color:var(--sky-deep)}
.copyright{
  position:relative;
  margin-top:36px; padding-top:18px;
  border-top:1px solid rgba(255,255,255,.25);
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px; color:rgba(255,255,255,.85);
}


/* ============ PHP Site: Placeholder Pages ============ */
.placeholder-page{text-align:center; padding:80px 0; max-width:600px; margin:0 auto}
.placeholder-icon{width:80px; height:80px; margin:0 auto 24px; border-radius:20px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center}
.placeholder-photo{width:100%; max-width:440px; margin:0 auto 24px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md)}
.placeholder-photo img{width:100%; height:auto; display:block}
.placeholder-page h2{margin-bottom:12px}
.placeholder-page p{color:var(--ink-soft); font-size:16px}
.placeholder-page a{color:var(--sky-deep); font-weight:700; text-decoration:underline}

/* ============================================================
   Employee auth, portal & maintenance wizard
   (login gate, portal grid, requests table, Request wizard)
   ============================================================ */

/* author display rules (flex/inline-flex) otherwise beat the UA [hidden] rule,
   so toggling el.hidden wouldn't actually hide overlays, buttons, errors, etc. */
[hidden]{display:none !important}

/* ---- Blur gate ---- */
#appShell{transition:filter .45s ease, opacity .45s ease}
#appShell.is-blurred{filter:blur(8px); pointer-events:none; user-select:none}

/* ---- Login overlay (shared component) ---- */
.login-overlay{
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:flex-start; justify-content:center;
  padding-top:14vh;                 /* slight upward optical shift */
  background:rgba(7,62,107,.28);
  opacity:0; transition:opacity .26s ease;
}
.login-overlay.open{opacity:1}
.login-card{
  width:min(92vw, 380px);
  background:#fff; border-radius:var(--r-lg);
  box-shadow:var(--shadow-md);
  padding:30px 28px 26px;
  transform:translateY(8px) scale(.98);
  transition:transform .26s cubic-bezier(.2,.8,.2,1);
  position:relative;
}
.login-overlay.open .login-card{transform:translateY(0) scale(1)}
.login-card.shake{animation:kkshake .4s}
@keyframes kkshake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(3px)}}
.login-brand{display:flex; align-items:center; gap:10px; margin-bottom:18px}
.login-mark{width:38px; height:38px; display:grid; place-items:center}
.login-mark img{width:100%; height:100%; object-fit:contain}
.login-wm{font-family:'Outfit'; font-weight:800; font-size:18px; color:var(--ink)}
.login-wm sup{font-size:8px; color:var(--ink-soft)}
.login-title{font-size:23px; font-weight:800; letter-spacing:-.02em; margin-bottom:4px}
.login-sub{color:var(--ink-soft); font-size:14px; margin:0 0 18px}
.login-field{display:flex; flex-direction:column; gap:6px; margin-bottom:13px}
.login-field label{font-family:'Outfit'; font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft)}
.login-inputwrap{display:flex; align-items:center; gap:9px; padding:0 13px; border:1.5px solid var(--line); border-radius:11px; background:#fff; transition:border-color .15s, box-shadow .15s}
.login-inputwrap:focus-within{border-color:var(--sky); box-shadow:0 0 0 4px rgba(26,111,181,.12)}
.login-inputwrap svg{color:var(--ink-soft); flex:none}
.login-inputwrap input{flex:1; border:0; outline:0; padding:12px 0; font-family:'Nunito'; font-size:15px; color:var(--ink); background:transparent}
.login-error{
  background:rgba(242,106,86,.1); color:var(--coral-deep);
  font-size:13px; font-weight:700; font-family:'Outfit';
  padding:9px 12px; border-radius:9px; margin:0 0 13px;
  display:flex; align-items:center; gap:7px;
}
.login-error::before{content:"⚠"; font-size:14px}
.login-submit{
  width:100%; background:var(--sky-deep); color:#fff;
  font-family:'Outfit'; font-weight:800; font-size:15px;
  padding:14px; border-radius:12px;
  box-shadow:0 3px 0 var(--sky-darker), 0 8px 18px rgba(11,79,134,.28);
  transition:transform .12s;
}
.login-submit:hover{transform:translateY(-1px)}
.login-spinner{display:flex; flex-direction:column; align-items:center; gap:14px; padding:26px 0 10px}
.login-spinner-text{font-family:'Outfit'; font-weight:700; color:var(--sky-deep); font-size:14px}
.spin{
  width:38px; height:38px; border-radius:50%;
  border:3.5px solid var(--sky-soft); border-top-color:var(--sky-deep);
  animation:kkspin .8s linear infinite;
}
@keyframes kkspin{to{transform:rotate(360deg)}}

/* ---- Employee Portal grid ---- */
.portal{padding:40px 0 70px}
.portal-grid{
  display:grid; gap:18px;
  grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
}
.portal-tile{
  position:relative; display:flex; flex-direction:column; gap:4px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); padding:22px 20px 18px; min-height:148px;
  transition:transform .14s ease, box-shadow .14s ease;
}
.portal-tile.live{cursor:pointer}
.portal-tile.live:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.portal-tile.dim{opacity:.6; filter:saturate(.55)}
.pt-icon{
  width:48px; height:48px; border-radius:14px; display:grid; place-items:center;
  background:var(--sky-soft); color:var(--sky-deep); margin-bottom:12px;
}
.portal-tile.coral .pt-icon{background:rgba(242,106,86,.14); color:var(--coral-deep)}
.portal-tile.mint  .pt-icon{background:rgba(63,178,142,.16); color:var(--mint)}
.portal-tile.lav   .pt-icon{background:rgba(122,102,196,.15); color:var(--lavender)}
.portal-tile.pink  .pt-icon{background:rgba(233,98,138,.15); color:var(--pink)}
.pt-label{font-family:'Outfit'; font-weight:800; font-size:17px; letter-spacing:-.01em}
.pt-desc{color:var(--ink-soft); font-size:13px}
.pt-go{margin-top:auto; padding-top:10px; font-family:'Outfit'; font-weight:800; font-size:13px; color:var(--coral-deep)}
.pt-soon{
  margin-top:auto; padding-top:10px; font-family:'Outfit'; font-weight:800;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft);
}
.portal-tile .pt-soon::before{content:"●"; color:var(--sun); margin-right:6px; font-size:9px}

/* ---- Maintenance page ---- */
.maint{padding:4px 0 70px}
.maint-bar{display:flex; align-items:center; gap:16px; margin-bottom:22px; flex-wrap:wrap}
.maint-hint{font-size:12.5px; color:var(--ink-soft); font-weight:700; font-family:'Outfit'}
.maint-count{font-size:12px; color:var(--ink-soft); font-weight:700}
.maint-tablewrap{overflow-x:auto}
.maint-table{width:100%; border-collapse:collapse; font-size:14px}
.maint-table th{
  text-align:left; padding:13px 18px; font-family:'Outfit'; font-weight:800;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft);
  border-bottom:1px solid var(--line);
}
.maint-table td{padding:14px 18px; border-bottom:1px solid var(--line-soft)}
.maint-table tr:last-child td{border-bottom:0}
.maint-table tbody tr:hover{background:var(--line-soft)}
.mr-id{font-family:'JetBrains Mono'; font-size:13px; color:var(--sky-deep); font-weight:500}
.mr-status{
  display:inline-block; padding:4px 11px; border-radius:999px;
  font-family:'Outfit'; font-weight:800; font-size:11.5px;
}
.mr-status[data-tone="ok"]{background:rgba(63,178,142,.16); color:#1f7a5c}
.mr-status[data-tone="warn"]{background:rgba(255,200,87,.22); color:#9a6a00}
.mr-status[data-tone="sky"]{background:var(--sky-soft); color:var(--sky-deep)}
.mr-flags{
  display:inline-grid; place-items:center; min-width:26px; height:26px; padding:0 8px;
  border-radius:999px; font-family:'Outfit'; font-weight:800; font-size:13px;
}
.mr-flags.ok{background:var(--line-soft); color:var(--ink-soft)}
.mr-flags[data-tone="warn"]{background:rgba(255,200,87,.25); color:#9a6a00}
.mr-flags[data-tone="bad"]{background:rgba(242,106,86,.16); color:var(--coral-deep)}
.maint-empty{padding:34px; text-align:center; color:var(--ink-soft); font-weight:700}

/* ---- Request wizard overlay ---- */
.wizard-overlay{
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:flex-start; justify-content:center;
  padding:5vh 16px;
  background:rgba(7,62,107,.34); opacity:0; transition:opacity .26s ease;
}
.wizard-overlay.open{opacity:1}
.wizard{
  width:min(96vw, 860px); max-height:90vh;
  background:var(--bg); border-radius:var(--r-lg); box-shadow:var(--shadow-md);
  display:flex; flex-direction:column; overflow:hidden;
  transform:translateY(10px) scale(.985); transition:transform .26s cubic-bezier(.2,.8,.2,1);
}
.wizard-overlay.open .wizard{transform:none}
.wizard-head{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:18px 22px; background:#fff; border-bottom:1px solid var(--line);
}
.wh-left{display:flex; align-items:center; gap:13px}
.wh-mark{width:42px; height:42px; border-radius:12px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none}
.wh-mark svg{width:22px; height:22px}
.wh-left h2{font-size:19px; font-weight:800; letter-spacing:-.02em}
.wh-sub{margin:1px 0 0; font-size:12.5px; color:var(--ink-soft)}
.wh-right{display:flex; align-items:center; gap:10px}
.lang-toggle{display:flex; background:var(--line-soft); border-radius:999px; padding:3px}
.lang-opt{padding:6px 13px; border-radius:999px; font-family:'Outfit'; font-weight:800; font-size:12px; color:var(--ink-soft)}
.lang-opt.on{background:#fff; color:var(--sky-deep); box-shadow:var(--shadow-xs)}
.wizard-close{width:34px; height:34px; border-radius:10px; display:grid; place-items:center; color:var(--ink-soft); background:var(--line-soft)}
.wizard-close:hover{background:var(--line); color:var(--ink)}

.wizard-progress{height:5px; background:var(--line-soft)}
.wp-bar{display:block; height:100%; width:16%; background:linear-gradient(90deg, var(--sky), var(--mint)); transition:width .35s cubic-bezier(.2,.8,.2,1)}
.wizard-stepline{display:flex; align-items:baseline; justify-content:space-between; gap:12px; padding:12px 22px 0}
.wsl-count{font-family:'Outfit'; font-weight:700; font-size:12px; letter-spacing:.04em; color:var(--ink-soft); text-transform:uppercase}
.wsl-count b{color:var(--sky-deep)}
.wsl-title{font-family:'Outfit'; font-weight:800; font-size:16px; color:var(--ink); letter-spacing:-.01em}

.wizard-form{overflow-y:auto; padding:14px 22px 22px}
.wizard-page{animation:wzfade .25s ease}
@keyframes wzfade{from{opacity:0; transform:translateY(6px)}to{opacity:1; transform:none}}

.wz-section{background:#fff; border:1px solid var(--line); border-radius:var(--r); margin-top:14px; overflow:hidden}
.wz-section:first-child{margin-top:8px}
.wz-sec-head{width:100%; display:flex; align-items:center; flex-wrap:wrap; gap:4px 10px; padding:14px 16px; text-align:left}
.wz-sec-title{font-family:'Outfit'; font-weight:800; font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:var(--sky-deep)}
.wz-sec-desc{font-size:12px; color:var(--ink-soft); font-weight:600; width:100%}
.wz-section.collapsible .wz-sec-head{cursor:pointer}
.wz-chev{margin-left:auto; font-size:16px; color:var(--ink-soft); transition:transform .2s}
.wz-section.collapsed .wz-chev{transform:rotate(-90deg)}
.wz-sec-body{padding:4px 16px 16px}
.wz-section.collapsed .wz-sec-body{display:none}
.wz-section.collapsible .wz-sec-head + .wz-sec-body{border-top:1px solid var(--line-soft); padding-top:14px}

.wz-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:14px 16px}
.wz-field{display:flex; flex-direction:column; gap:7px}
.wz-field.wide{grid-column:1 / -1}
.wz-label{display:flex; align-items:center; gap:7px; font-family:'Outfit'; font-weight:700; font-size:12.5px; color:var(--ink)}
.wz-fi{width:24px; height:24px; border-radius:7px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none}
.wz-fi svg{width:15px; height:15px}
.wz-req{color:var(--coral); font-weight:800}
.wz-input{
  font-family:'Nunito'; font-size:14.5px; color:var(--ink);
  padding:11px 13px; border:1.5px solid var(--line); border-radius:10px;
  background:#fff; outline:none; width:100%;
  transition:border-color .15s, box-shadow .15s;
}
.wz-input:focus{border-color:var(--sky); box-shadow:0 0 0 4px rgba(26,111,181,.12)}
.wz-input.invalid{border-color:var(--coral); box-shadow:0 0 0 4px rgba(242,106,86,.14)}
.wz-textarea{resize:vertical; min-height:74px}

/* select with colour tone */
.wz-select-wrap{position:relative; display:flex; align-items:center}
.wz-select-wrap select{appearance:none; padding-right:38px}
.wz-tone-dot{position:absolute; right:13px; width:11px; height:11px; border-radius:50%; background:var(--line); pointer-events:none}
.wz-select-wrap[data-tone="ok"]   select{border-color:rgba(63,178,142,.55); background:rgba(63,178,142,.07)}
.wz-select-wrap[data-tone="ok"]   .wz-tone-dot{background:var(--mint)}
.wz-select-wrap[data-tone="warn"] select{border-color:rgba(255,200,87,.7); background:rgba(255,200,87,.1)}
.wz-select-wrap[data-tone="warn"] .wz-tone-dot{background:#E8A52B}
.wz-select-wrap[data-tone="bad"]  select{border-color:rgba(242,106,86,.6); background:rgba(242,106,86,.07)}
.wz-select-wrap[data-tone="bad"]  .wz-tone-dot{background:var(--coral)}

.wz-check{display:inline-flex; align-items:center; gap:9px; cursor:pointer; padding:9px 0}
.wz-check input{position:absolute; opacity:0; width:0; height:0}
.wz-check-box{width:22px; height:22px; border-radius:7px; border:1.5px solid var(--line); display:grid; place-items:center; transition:background .15s, border-color .15s}
.wz-check-box::after{content:"✓"; color:#fff; font-size:14px; font-weight:800; opacity:0; transform:scale(.6); transition:.15s}
.wz-check input:checked + .wz-check-box{background:var(--mint); border-color:var(--mint)}
.wz-check input:checked + .wz-check-box::after{opacity:1; transform:none}
.wz-check-txt{font-family:'Outfit'; font-weight:700; font-size:14px}

/* notes: voice + translate */
.wz-notes{position:relative}
.wz-notes-tools{display:flex; justify-content:flex-end; gap:8px; margin-top:8px}
.wz-tool{display:inline-flex; align-items:center; gap:7px; padding:8px 13px; border-radius:10px; background:var(--sky-soft); color:var(--sky-deep); font-family:'Outfit'; font-weight:700; font-size:12.5px; transition:background .15s, transform .12s}
.wz-tool:hover{transform:translateY(-1px)}
.wz-translate{background:rgba(122,102,196,.13); color:var(--lavender)}
.wz-mic.rec{background:var(--coral); color:#fff; animation:kkpulse 1.1s ease-in-out infinite}
@keyframes kkpulse{0%,100%{box-shadow:0 0 0 0 rgba(242,106,86,.45)}50%{box-shadow:0 0 0 7px rgba(242,106,86,0)}}
.wz-voice-status{display:block; text-align:right; margin-top:6px; font-size:12px; font-weight:700; color:var(--ink-soft)}

/* upload */
.wz-upload-drop{display:inline-flex; align-items:center; gap:9px; padding:13px 18px; border:1.5px dashed var(--line); border-radius:11px; color:var(--sky-deep); background:var(--line-soft); font-family:'Outfit'; font-weight:700; font-size:13.5px; cursor:pointer; transition:border-color .15s, background .15s}
.wz-upload-drop:hover{border-color:var(--sky); background:var(--sky-soft)}
.wz-upload-preview{margin-top:12px; display:flex; align-items:center; gap:14px}
.wz-upload-preview img{width:96px; height:96px; object-fit:cover; border-radius:12px; border:1px solid var(--line)}
.wz-upload-remove{color:var(--coral-deep); font-family:'Outfit'; font-weight:800; font-size:13px; text-decoration:underline}

.wizard-foot{display:flex; align-items:center; gap:12px; padding:14px 22px; background:#fff; border-top:1px solid var(--line)}
.wf-spacer{flex:1}
.wiz-err{color:var(--coral-deep); font-family:'Outfit'; font-weight:700; font-size:13px}
.wiz-back{order:-1}
.wiz-submit.done{background:var(--mint); box-shadow:0 4px 0 #2f7a5c}

@media (max-width:680px){
  .wz-grid{grid-template-columns:1fr}
  .wh-sub{display:none}
  .wizard-stepline{flex-direction:column; gap:2px}
}

/* ============================================================
   Responsive — the base stylesheet is desktop-only; this block
   adds tablet/phone breakpoints site-wide.
   Header on mobile: brand + the 3 CTA buttons on top row,
   nav tabs in a scrollable row beneath.
   ============================================================ */

html, body { overflow-x: hidden; }   /* safety net: never let a stray wide row push the page sideways */

/* ---- Header: stack nav beneath brand + buttons ----
   Grid lays out row 1 (brand | cta) and row 2 (nav) without flex-wrap,
   so the cta cannot drop below the brand when the row gets tight. */
@media (max-width: 1024px) {
  .topbar-inner {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas: "brand cta" "nav nav";
    row-gap: 8px;
    column-gap: 0px;
    padding: 12px 0;
  }
  .brand   { grid-area: brand; }
  .top-cta { grid-area: cta; justify-self: end; flex-wrap: nowrap; }
  .top-nav {
    grid-area: nav;
    justify-content: flex-start;
    overflow-x: auto; -webkit-overflow-scrolling: touch;
    gap: 2px; padding-bottom: 2px;
    scrollbar-width: none;
    border-top: 1px solid var(--line-soft); padding-top: 8px;
  }
  .top-nav::-webkit-scrollbar { display: none; }
  .top-nav a { white-space: nowrap; padding: 9px 13px; }
  /* hover dropdowns aren't tappable on touch — show top-level tabs only */
  .nav-drop { display: none; }
  .top-nav .caret { display: none; }
}

/* ---- Tablet: collapse the wide two-pane splits, thin the gutters ---- */
@media (max-width: 1024px) {
  .wrap { padding: 0 28px; }
  .hero, .hero-left,
  .media-grid, .about-grid, .contact-grid, .news-wrap, .content-grid,
  .hero-row, .head-inner, .ada-grid, .careers, .mission, .reqs-band,
  .newsletter, .feat-card, .item, .tour-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  /* 3–4 col card rows → 2 col */
  .news-grid, .tiles, .rev-grid, .pos-grid, .ben-grid, .facts,
  .family-days, .curr-grid, .about-stats, .footer-grid, .grid,
  .v-thumbs, .portal-grid, .help-row {
    grid-template-columns: repeat(2, 1fr);
  }
  .page-head h1 { font-size: 40px; }
  .sec-head h2  { font-size: 28px; }
  .sec-head { flex-wrap: wrap; gap: 10px; }
  /* big hero/section bands tighten their vertical rhythm */
  .hero-band, .prog-hero { padding: 36px 0 40px; }
  .reqs-band { margin-bottom: 40px; }
}

/* ---- Phone: single column everywhere, tighter rhythm ---- */
@media (max-width: 600px) {
  .wrap { padding: 18px; }
  .news-grid, .tiles, .rev-grid, .pos-grid, .ben-grid, .facts,
  .family-days, .curr-grid, .footer-grid, .grid, .faq-list,
  .form .row, .portal-grid, .help-row, .v-thumbs {
    grid-template-columns: 1fr;
  }
  .about-stats { grid-template-columns: repeat(3, 1fr); }   /* small stat chips stay inline */
  /* hero/section bands: phone padding */
  .hero-band, .prog-hero { padding: 26px 0 30px; }
  .drawer-band { padding: 20px 18px; }
  .reqs-band { margin-bottom: 30px; }
  .year-band { margin: 22px 0 10px; }
  .slots { grid-template-columns: repeat(3, 1fr) !important; }
  .page-head { padding: 0; }
  .page-head h1 { font-size: 31px; }
  .page-head p  { font-size: 15px; }
  .hero h1 { font-size: 40px; }

  /* row 1: brand + lang + 3 pill buttons on one line; nav wraps to row 2 (see 1024px block above).
     Sizes here clear Lighthouse "legible font sizes" (≥12px) and "tap targets" (≥48px touch area). */
  .pill .pill-label { display: none; }
  .pill { padding: 9px; gap: 0; min-width: 38px; min-height: 38px; }
  .pill svg { width: 15px; height: 15px; }
  .top-cta { gap: 2px; flex-wrap: nowrap; align-items: center; }
  .brand { gap: 8px; flex: 0 0 auto; min-width: 0; }
  .brand-text .tg { letter-spacing: .2em; font-size: 11px; }
  .topbar-lang { margin-right: 0; height: auto; }
  .topbar-lang .lang-opt { padding: 8px 9px; font-size: 12px; min-height: 38px; }

  /* overlays go full-bleed and scrollable on small screens */
  .login-card { width: 100%; }
  .wizard { width: 100%; max-height: 94vh; }
  .wizard-foot { flex-wrap: wrap; }
  .maint-bar { gap: 10px; }
}

/* very small: shrink the brand wordmark a touch more */
@media (max-width: 380px) {
  .brand-mark { width: 38px; height: 38px; }
  .brand-text .wm { font-size: 19px; }
  .hero h1 { font-size: 39px; }
}

/* ============================================================
   Maintenance Audit — Schools grid, Dashboard, Category,
   Summary, Blueprint, History, Asset Order
   ============================================================ */
.maint-schools .schools-h{ margin:8px 0 14px; }
.maint-schools .schools-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:18px; margin-top:8px;
}
.school-card{
  display:flex; align-items:center; gap:14px; padding:16px; min-height:166px;
  background:#fff; border:2px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-xs); transition:transform .15s, box-shadow .15s;
}
.school-card:hover{ transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.school-card-icon{ width:46px; height:46px; border-radius:12px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.school-card-icon svg{ width:26px; height:26px; }
.school-card-body{ display:flex; flex-direction:column; gap:8px; min-width:0; flex:1 1 auto; }
/* Name on top; icon + address share the row beneath it */
.school-card-row{ display:flex; align-items:center; gap:12px; min-width:0; }
.school-card-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.school-card-radial-wrap{ position:relative; width:86px; flex:none; display:flex; flex-direction:column; align-items:center; gap:4px; margin-left:auto; }
.school-card-radial-wrap .school-radial{ width:86px; height:86px; }
.school-card-pct{
  position:absolute; top:0; left:0; right:0; height:86px;
  display:grid; place-items:end center; padding-bottom:14%; pointer-events:none;
  font-family:'Outfit'; font-weight:800; font-size:14px; color:var(--sky-deep);
  text-shadow:0 0 6px rgba(255,255,255,.85);
}
/* 100% pass = full disc → center the % instead of seating it at the base */
.school-card-pct.is-full{ place-items:center; padding-bottom:0; }
.school-card-name{ font-family:'Outfit'; font-weight:800; font-size:26px; color:var(--ink); line-height:1.15; }
.school-card-area{ font-size:12px; font-weight:700; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.08em; }
.school-card-address{ font-size:12px; font-weight:600; color:var(--ink-soft); line-height:1.3; margin-top:2px; }
.school-card-stamp{ font-size:11px; font-weight:700; color:var(--ink-soft); text-align:center; line-height:1.2; }
.school-card-stamp[data-tone="ok"]{ color:var(--mint); }
.school-card-stamp[data-tone="warn"]{ color:#E8A52B; }
.school-card-stamp[data-tone="bad"]{ color:var(--coral-deep); }
.schools-h-row{ display:flex; align-items:center; gap:10px; margin:8px 0 14px; }
.schools-h-row .schools-h{ margin:0; }
.schools-h-count{
  margin-left:auto; font-family:'Outfit'; font-weight:800; font-size:13px;
  color:var(--sky-deep); background:var(--sky-soft); border:1px solid var(--line);
  border-radius:999px; padding:3px 11px; min-width:28px; text-align:center;
}

/* Micro legend for the school pie charts (dots mirror the wedge fill + bright stroke) */
.schools-legend{ display:flex; flex-wrap:wrap; gap:8px; margin:-4px 0 16px; }
.sl-item{ display:inline-flex; align-items:center; gap:6px; font-family:'Outfit'; font-weight:700; font-size:12px; color:var(--ink-soft); background:none; border:1px solid transparent; border-radius:99px; padding:5px 11px; cursor:pointer; transition:background .15s, border-color .15s, color .15s; }
.sl-item:hover{ background:var(--line-soft); }
.sl-item.on{ background:#fff; border-color:var(--line); color:var(--ink); box-shadow:var(--shadow-xs); }
.sl-dot{ width:11px; height:11px; border-radius:50%; flex:none; border:1.5px solid; }
/* Audit tones (maintenance) */
.sl-dot[data-tone="pass"]{ background:rgba(63,178,142,.32); border-color:#3FB28E; }
.sl-dot[data-tone="warn"]{ background:rgba(232,165,43,.34); border-color:#E8A52B; }
.sl-dot[data-tone="fail"]{ background:rgba(242,106,86,.34); border-color:#F26A56; }
/* Severity tones (inventory) */
.sl-dot[data-tone="sev-low"]{    background:var(--sev-low);    border-color:var(--sev-low); }
.sl-dot[data-tone="sev-medium"]{ background:var(--sev-medium); border-color:var(--sev-medium); }
.sl-dot[data-tone="sev-high"]{   background:var(--sev-high);   border-color:var(--sev-high); }
.sl-dot[data-tone="sev-urgent"]{ background:var(--sev-urgent); border-color:var(--sev-urgent); }

/* Radial SVG — filled pie slices (pass/warn/fail), white backing behind */
.school-radial{ width:100%; height:100%; color:var(--sky-deep); display:block; }
.school-radial .sr-bg{ stroke:var(--line); stroke-width:1.5; fill:#FFF; }

/* Dashboard status row — slim, no duplicate banner */
/* Compact top progress: big % + bar (one row), counts left + Today·time right (next row) */
.sd-status{
  display:flex; flex-direction:column; gap:9px; padding:13px 15px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  margin:8px 0 14px;
}
.sd-status-top{ display:flex; align-items:center; gap:12px; }
.sd-status-pct{ font-family:'Outfit'; font-weight:800; font-size:26px; color:var(--ink); line-height:1; letter-spacing:-.01em; flex:none; }
.sd-bar{ flex:1; display:flex; height:7px; border-radius:5px; overflow:hidden; background:var(--line-soft); }
.sd-bar-seg{ display:block; height:100%; width:0; transition:width .3s ease; }
.sd-bar-pass{ background:var(--mint); }
.sd-bar-warn{ background:#E8A52B; }
.sd-bar-fail{ background:var(--coral); }
.sd-status-bot{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.sd-status-counts{ font-size:12px; font-weight:700; color:var(--ink-soft); }
.sd-c-pass{ color:var(--mint); }
.sd-status-counts a.sd-status-link{ font-weight:800; }
.sd-c-warn{ color:#C2902A; }
.sd-c-fail{ color:var(--coral-deep); }
.sd-status-stamp{ font-size:12px; font-weight:700; color:var(--ink-soft); flex:none; }

/* On mobile the status bar is relocated into the page-head; keep the pie right-aligned. */
.page-head .sd-status{ margin:14px 0 0; }

/* Mobile: school-name header sticks below the topbar and compacts on scroll
   (shrinks the name, hides the address/crumbs/back/status). */
@media (max-width:720px){
  .school-head-bar{
    position:sticky; top:var(--topbar-h, 58px); z-index:90;
    background:#fff; transition:padding .18s ease, box-shadow .18s ease;
  }
  .school-head-bar h1{ transition:font-size .18s ease, margin .18s ease; }
  .school-head-bar.is-stuck{
    padding-top:8px; padding-bottom:8px;
    box-shadow:0 6px 14px -10px rgba(11,79,134,.4);
    border-bottom:1px solid var(--line);
  }
  .school-head-bar.is-stuck h1{ font-size:20px; margin:0; }
  .school-head-bar.is-stuck .crumbs,
  .school-head-bar.is-stuck .school-head > p,
  .school-head-bar.is-stuck .page-back,
  .school-head-bar.is-stuck .sd-status{ display:none; }
}

/* Blueprint — schematic layout, landscape on desktop / portrait on mobile */
.sd-blueprint{ padding:14px; display:flex; flex-direction:column; gap:12px; grid-column:1 / -1; }
.sd-blueprint-h{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; flex-wrap:wrap; }
.sd-blueprint-h .ttl{ font-family:'Outfit'; font-weight:800; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-deep); }
.sd-blueprint-hint{ font-size:11px; color:var(--ink-soft); font-weight:700; }

.bp-svg{ width:100%; height:auto; display:block; }
.bp-svg-landscape{ max-height:75vh; }
.bp-svg-portrait{ display:none; }
@media (max-width:720px){
  .bp-svg-landscape{ display:none; }
  .bp-svg-portrait{ display:block; }
}

.bp-zone{ cursor:pointer; transition:opacity .15s; outline:none; }
.bp-zone:hover .bp-room{ filter:brightness(.97); }
.bp-zone:focus-visible .bp-room{ stroke-width:3 !important; }
.bp-zone[data-tone="warn"] .bp-room{ stroke:#E8A52B !important; stroke-width:2.5 !important; }
.bp-zone[data-tone="bad"]  .bp-room{ stroke:#F26A56 !important; stroke-width:2.5 !important; }
.bp-zone[data-tone="ok"]   .bp-room{ stroke-opacity:.85; }
.bp-label{ font-family:'Outfit', sans-serif; font-weight:700; font-size:13px; fill:var(--ink); }

/* Category tiles */
.sd-section-h{ font-family:'Outfit'; font-weight:800; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-deep); margin:28px 0 12px; }
/* Dashboard: categories (¼) left of the blueprint (¾) */
.sd-dash{ display:grid; grid-template-columns:1fr 3fr; gap:16px; align-items:start; }
.sd-dash .sd-blueprint{ grid-column:auto; margin:0; }
.sd-cats{ display:flex; flex-direction:column; min-width:0; }
.sd-cats .sd-section-h{ margin:0 0 10px; }
@media (max-width:720px){
  .sd-dash{ display:block; }
  .sd-cats{ display:none; }   /* categories live in the blueprint's Categories tab on mobile */
}
.cat-tiles{
  display:flex; flex-direction:column; gap:10px;
}
.cat-tile{
  display:flex; align-items:center; gap:12px; padding:14px;
  background:#e4eff8; border:1px solid var(--line); border-radius:var(--r);
  transition:transform .15s, border-color .15s;
}
.cat-tile:hover{ transform:translateY(-2px); border-color:var(--sky); }
.cat-tile-icon{ width:34px; height:34px; border-radius:9px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.cat-tile-icon svg{ width:18px; height:18px; }
.cat-tile-name{ font-family:'Outfit'; font-weight:800; font-size:14px; flex:1; min-width:0; }
.cat-tile-chips{ display:flex; gap:5px; flex:none; }

/* Colored, icon-less group status chips (broken/help/all-pass) */
.ac-chip{ font-family:'Outfit'; font-weight:800; font-size:11px; padding:4px 10px; border-radius:20px; white-space:nowrap; }
.ac-chip-bad{ background:rgba(242,106,86,.16); color:var(--coral-deep); }
.ac-chip-warn{ background:rgba(232,165,43,.2); color:#B5811F; }
.ac-chip-ok{ background:rgba(63,178,142,.18); color:#157A4E; }

.sd-foot, .cat-foot{ display:flex; justify-content:flex-end; gap:10px; margin-top:24px; }

/* Back hyperlink beneath the school address (replaces the lone maint-bar button) */
.page-back{ display:inline-flex; align-items:center; gap:6px; font-family:'Outfit'; font-weight:700; font-size:14px; color:var(--sky-deep); }
.page-back svg{ width:16px; height:16px; }
.page-back:hover{ text-decoration:underline; }
/* One row holding the Back link (left) and the action slot e.g. Summary (right). */
.nav-container{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-top:14px; }
.page-head-slot{ display:flex; align-items:center; gap:8px; margin-left:auto; }
.school-head-summary{ padding:9px 18px; font-size:13.5px; }
/* Clickable status pieces in dashboard status bar. */
.sd-status-link{ color:inherit; text-decoration:underline; text-decoration-thickness:1.5px; text-underline-offset:2px; cursor:pointer; }
.sd-status-link:hover{ color:var(--sky-deep); }
/* Subhead chip inside Show All drawer when filtered by status. */
.bp-drawer-sub{ margin:0 0 10px; padding:6px 12px; background:var(--sky-soft); border:1px solid var(--line); border-radius:99px; font-family:'Outfit'; font-weight:800; font-size:12px; color:var(--sky-deep); display:inline-block; text-transform:uppercase; letter-spacing:.08em; }

/* Show All button in the blueprint header (replaces the "tap a room" hint) */
.bp-showall{ font-family:'Outfit'; font-weight:800; font-size:12px; letter-spacing:.03em; color:var(--sky-deep); background:var(--sky-soft); border:1px solid var(--line); border-radius:99px; padding:5px 14px; cursor:pointer; transition:background .15s, border-color .15s; }
.bp-showall:hover{ background:#fff; border-color:var(--sky); }

/* Blueprint Building/Categories tabs (mobile only) */
.bp-tabs{ display:none; }
.bp-tab{ font-family:'Outfit'; font-weight:800; font-size:13px; padding:7px 16px; border-radius:99px; color:var(--ink-soft); background:var(--line-soft); border:1px solid transparent; cursor:pointer; }
.bp-tab.on{ background:var(--sky-soft); color:var(--sky-deep); border-color:var(--line); }
.bp-panel[hidden]{ display:none; }
.bp-panel-categories .cat-tiles{ margin-top:4px; }
@media (min-width:721px){ .bp-panel-categories{ display:none !important; } }
@media (max-width:720px){
  .bp-tabs{ display:flex; gap:6px; }
  .sd-blueprint-h{ align-items:center; }
  .sd-blueprint-h .ttl{ display:none; }
  #catSectionH{ display:none; }
}

/* Category tiles double as mobile accordions */
.cat-acc{ display:flex; flex-direction:column; }
.cat-tile{ width:100%; font:inherit; text-align:left; cursor:pointer; }
.cat-tile-chev{ flex:none; display:grid; place-items:center; color:var(--ink-soft); transition:transform .2s; }
.cat-tile-chev svg{ width:18px; height:18px; }
.cat-tile[aria-expanded="true"]{ border-color:var(--sky); border-bottom-left-radius:0; border-bottom-right-radius:0; }
.cat-tile[aria-expanded="true"] .cat-tile-chev{ transform:rotate(180deg); }
.cat-acc-body{ border:1px solid var(--sky); border-top:0; border-radius:0 0 var(--r) var(--r); padding:6px 12px 12px; background:#fff; }
.cat-acc-body .audit-items{ margin-top:6px; }
@media (min-width:721px){ .cat-tile-chev{ display:none; } }

/* Blueprint audit surface (desktop). Default = centered modal (zone/category clicks).
   .bp-as-drawer = right-aligned, full-height drawer (Show All only). */
@media (min-width:721px){
  .bp-drawer{ align-items:center; justify-content:center; padding:24px; }
  .bp-drawer-sheet{ width:min(720px, 100%); height:auto; max-height:86vh; border-radius:18px; transform:translateY(18px); box-shadow:var(--shadow-md); }
  .bp-drawer.open .bp-drawer-sheet{ transform:none; }

  .bp-drawer.bp-as-drawer{ align-items:stretch; justify-content:flex-end; padding:0; }
  .bp-drawer.bp-as-drawer .bp-drawer-sheet{ width:min(480px, 100%); height:100dvh; max-height:none; border-radius:0; transform:translateX(40px); }
  .bp-drawer.bp-as-drawer.open .bp-drawer-sheet{ transform:none; }
}

/* Show All accordion — framed group panels with a neutral header + colored chips */
.bp-acc-grouph{ font-family:'Outfit'; font-weight:800; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--sky-deep); margin:18px 0 8px; }
.bp-acc-grouph:first-child{ margin-top:0; }
.bp-acc-sec{ border:1px solid var(--line); border-radius:14px; margin-bottom:10px; overflow:hidden; box-shadow:0 1px 3px rgba(11,79,134,.05); }
.bp-acc-head{ width:100%; display:flex; align-items:center; gap:10px; padding:11px 14px; background:var(--line-soft); border-bottom:1px solid var(--line); cursor:pointer; font:inherit; text-align:left; }
.bp-acc-head[aria-expanded="false"]{ border-bottom-color:transparent; }
.bp-acc-head:hover{ filter:brightness(.98); }
.ac-cat-icon{ width:24px; height:24px; display:grid; place-items:center; color:var(--sky-deep); flex:none; }
.ac-cat-icon svg{ width:19px; height:19px; }
.bp-acc-name{ flex:1; font-family:'Outfit'; font-weight:800; font-size:15px; min-width:0; color:var(--ink); }
.ac-chips{ display:flex; gap:5px; flex:none; }
.bp-acc-chev{ display:grid; place-items:center; color:var(--ink-soft); transition:transform .2s; flex:none; }
.bp-acc-chev svg{ width:18px; height:18px; }
.bp-acc-head[aria-expanded="true"] .bp-acc-chev{ transform:rotate(180deg); }
.bp-acc-body{ padding:0; }
/* Flatten cards into divided rows inside a group panel */
.bp-acc-body .audit-items, .cat-acc-body .audit-items{ margin-top:0; gap:0; }
.bp-acc-body .audit-card, .cat-acc-body .audit-card{ border:0; border-radius:0; box-shadow:none; }
.bp-acc-body .audit-card + .audit-card, .cat-acc-body .audit-card + .audit-card{ border-top:1px solid var(--line-soft); }

/* Tier sections stacked inside a zone's checklist (no tabs) */
.bp-tier-sec{ margin-top:16px; }
.bp-tier-h{ display:flex; align-items:center; gap:8px; margin:0 0 8px; font-family:'Outfit'; font-weight:800; font-size:14px; }
.bp-tier-thumb{ width:26px; height:26px; border-radius:7px; object-fit:cover; flex:none; }
.bp-tier-age{ font-size:11px; font-weight:700; color:var(--ink-soft); }

/* Category header card */
.cat-head{ display:flex; align-items:center; gap:14px; padding:18px; margin-top:8px; }
.cat-head-icon{ width:44px; height:44px; border-radius:11px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.cat-head-icon svg{ width:22px; height:22px; }
.cat-head-name{ margin:0; font-family:'Outfit'; font-weight:800; font-size:22px; }
.cat-head-meta{ margin:2px 0 0; font-size:13px; color:var(--ink-soft); font-weight:700; }

/* Audit items list — one .audit-card per asset, with per-tier value-rows inside */
.audit-items{ display:flex; flex-direction:column; gap:12px; margin-top:14px; }
.audit-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden;
}
.ac-head{ display:flex; align-items:flex-start; gap:12px; padding:14px 14px 10px; }
.ac-icon{ width:24px; height:24px; border-radius:10px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.ac-icon svg{ width:20px; height:20px; }
.ac-text{ flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.ac-name{ font-family:'Outfit'; font-weight:800; font-size:16px; color:var(--ink); line-height:1.25; }
.ac-meta{
  font-size:11.5px;
  font-weight:600;
  color:var(--ink-soft);
  opacity: .6;
}
.ac-text:hover .ac-meta {
  opacity: 1;
}
.ac-meta:empty{ display:none; }
.ai-tool{ width:34px; height:34px; border-radius:9px; background:var(--line-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.ai-tool svg{ width:16px; height:16px; }
.ai-tool:hover{ background:var(--sky-soft); }

.ac-vals{ display:flex; flex-direction:column; }
/* Per-tier (program) cards: center the program rows in the card */
.ac-vals.programs{ align-items:center; }
.ac-vals.programs .audit-item{ width:fit-content; max-width:100%; }
.ac-vals.programs .ai-row-tiered .ai-yesno{ flex:0 0 auto; }
.audit-item{ padding:4px 14px 14px;}
.audit-item.ai-disabled{ opacity:.55; }
.ai-row{ display:flex; flex-direction:column; gap:8px; }
/* Per-tier rows: program chip on the left, buttons take the rest of the row */
.ai-row-tiered{ flex-direction:row; align-items:center; gap:10px; }
.ai-row-tiered .ai-row-h{ width:118px; flex:none; }
.ai-row-tiered .ai-yesno{ flex:1; }
.ai-row-h{ display:flex; align-items:center; gap:7px; min-height:18px; }
.ai-tier{ display:inline-flex; align-items:center; gap:7px; font-family:'Outfit'; font-weight:700; font-size:12.5px; color:var(--ink); }
.ai-tier:empty{ display:none; }
.ai-tier-img{ width:21px; height:21px; border-radius:50%; object-fit:cover; flex:none; border:1px solid var(--line); }

/* Tri-state buttons: separated pills, only the SELECTED one is colored; others neutral grey */
.ai-yesno.ai-tristate{ display:grid; grid-template-columns:repeat(3, 1fr); gap:6px; }
.ai-yn{
  min-height:38px; border-radius:9px; padding:8px 6px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  font-family:'Mulish','Outfit',sans-serif; font-weight:700; font-size:13px;
  background:var(--line-soft); color:var(--ink-soft); border:1.5px solid transparent;
  transition:background .15s, color .15s, border-color .15s;
}
.ai-yn svg{ width:17px; height:17px; flex:none; }
.ai-yn span{ white-space:nowrap; }
.ai-yn:hover:not(:disabled){ color:var(--ink); }
/* Per-tier rows are tight (program chip + 3 controls) → icon-only buttons, no label */
.ai-row-tiered .ai-yn{ min-height:32px; gap:0; padding:6px 4px; }
.ai-row-tiered .ai-yn span{ display:none; }
.ai-row-tiered .ai-yn svg{ width:16px; height:16px; }
.audit-item[data-status="pass"] .ai-ok    { background:var(--mint);  color:#fff; box-shadow:0 1px 2px rgba(11,79,134,.2); }
.audit-item[data-status="warn"] .ai-help  { background:#E8A52B;      color:#fff; box-shadow:0 1px 2px rgba(11,79,134,.2); }
.audit-item[data-status="fail"] .ai-broken{ background:var(--coral); color:#fff; box-shadow:0 1px 2px rgba(11,79,134,.2); }
.ai-yn:disabled{ cursor:not-allowed; }

/* Numeric stepper: − [typeable value] + */
.ai-numeric .ai-row-tiered .ai-stepper{ flex:none; }
.ai-stepper{ display:inline-flex; align-items:center; gap:6px; background:var(--line-soft); border-radius:11px; padding:3px; width:max-content; }
.ai-step{ width:34px; height:34px; border-radius:8px; background:#fff; color:var(--sky-deep); font-family:'Outfit'; font-weight:800; font-size:19px; line-height:1; display:grid; place-items:center; box-shadow:0 1px 2px rgba(11,79,134,.12); cursor:pointer; }
.ai-step:hover:not(:disabled){ background:var(--sky-soft); }
.ai-step:disabled{ cursor:not-allowed; opacity:.5; box-shadow:none; }
.ai-step-val{ width:46px; text-align:center; font-family:'Outfit'; font-weight:800; font-size:18px; color:var(--ink); border:none; background:transparent; outline:none; padding:0; margin:0; }
.ai-numeric .ai-row:not(.ai-row-tiered){ flex-direction:row; justify-content:flex-end; }

/* Slide-open note panel */
.ai-note-panel{
  display:flex; flex-direction:column; gap:10px;
  max-height:0; overflow:hidden;
  padding:0; border-top:1px solid transparent;
  transition:max-height .25s ease, padding .25s ease, border-color .25s ease;
}
.ai-note-panel.open{ max-height:600px; padding:12px 0 4px; }
.ai-note-panel[hidden]{ display:none !important; }
.ai-note-wrap{ position:relative; }
.ai-note{ background:#F7F6F2 !important; padding-right:80px !important; padding-top:34px !important; }
.ai-note-pins{ position:absolute; right:8px; bottom:8px; display:flex; gap:6px; }
.ai-note-close{ position:absolute; top:8px; right:8px; width:26px; height:26px; border-radius:7px; background:#fff; border:1px solid var(--line); color:var(--ink-soft); display:grid; place-items:center; cursor:pointer; }
.ai-note-close svg{ width:14px; height:14px; }
.ai-note-close:hover{ color:var(--ink); background:var(--line-soft); }
.ai-pin{ width:32px; height:32px; border-radius:9px; background:#fff; border:1px solid var(--line); color:var(--sky-deep); display:grid; place-items:center; }
.ai-pin svg{ width:16px; height:16px; }
.ai-pin:hover{ background:var(--sky-soft); }
.ai-pin.rec{ background:var(--coral); color:#fff; border-color:var(--coral); }
.ai-reorder{
  align-self:flex-start; display:inline-flex; align-items:center; gap:8px;
  padding:9px 14px; border-radius:10px; font-family:'Outfit'; font-weight:800; font-size:13px;
  background:rgba(242,106,86,.12); color:var(--coral-deep); border:1px solid rgba(242,106,86,.4);
}
.ai-reorder svg{ width:16px; height:16px; }
.ai-reorder[hidden]{ display:none; }
.ai-photos{ display:flex; gap:8px; flex-wrap:wrap; }
.ai-photo-thumb{ width:72px; height:72px; border-radius:10px; overflow:hidden; border:1px solid var(--line); padding:0; }
.ai-photo-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.ai-mic-status{ font-size:12px; color:var(--ink-soft); font-weight:700; }

/* History drawer — right-side, one card per entry (stays a right drawer on desktop).
   The 2-class selector beats the later `.bp-drawer{ z-index:1000 }` rule on
   specificity, so the history drawer sits ABOVE the asset/blueprint drawer
   on mobile too (where both can be open at once). */
.bp-drawer.hist-drawer{ z-index:1100; }
.hist-sample-banner{ margin:0 0 12px; padding:8px 12px; background:var(--sky-soft); border:1px dashed var(--line); border-radius:10px; font-size:12px; font-weight:600; color:var(--sky-deep); }
.hist-meta{ display:flex; gap:8px; align-items:center; font-size:12px; font-weight:600; color:var(--ink-soft); }
.hist-inspector::before{ content:"👤 "; opacity:.7; }
@media (min-width:721px){
  .hist-drawer{ align-items:stretch; justify-content:flex-end; padding:0; }
  .hist-drawer .bp-drawer-sheet{ width:min(460px, 100%); height:100%; max-height:none; border-radius:0; transform:translateX(40px); box-shadow:-8px 0 32px -12px rgba(11,79,134,.25); }
  .hist-drawer.open .bp-drawer-sheet{ transform:none; }
}
.hist-entry{ border:1px solid var(--line); border-radius:12px; padding:12px 14px; margin-bottom:12px; display:flex; flex-direction:column; gap:8px; }
.hist-entry-h{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.hist-when{ font-size:12px; font-weight:700; color:var(--ink-soft); }
.hist-status{ font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; padding:3px 10px; border-radius:99px; }
.hist-status[data-tone="ok"]{ background:rgba(63,178,142,.16); color:var(--mint); }
.hist-status[data-tone="bad"]{ background:rgba(242,106,86,.16); color:var(--coral-deep); }
.hist-status[data-tone="warn"]{ background:rgba(255,200,87,.18); color:#A87014; }
.hist-note{ font-size:13px; color:var(--ink); margin:0; }
.hist-note.hist-empty{ color:var(--ink-soft); font-style:italic; }
.hist-photos{ display:flex; gap:6px; flex-wrap:wrap; }
.hist-photos img{ width:64px; height:64px; border-radius:8px; object-fit:cover; border:1px solid var(--line); cursor:zoom-in; }

/* Image lightbox (note + history photos) */
.img-viewer{ position:fixed; inset:0; z-index:1100; background:rgba(11,79,134,.72); display:grid; place-items:center; padding:24px; opacity:0; transition:opacity .2s; }
.img-viewer.open{ opacity:1; }
.img-viewer[hidden]{ display:none; }
.img-viewer-img{ max-width:92vw; max-height:88vh; border-radius:12px; box-shadow:var(--shadow-md); display:block; transform:scale(.97); transition:transform .2s; }
.img-viewer.open .img-viewer-img{ transform:none; }
.img-viewer-close{ position:fixed; top:18px; right:18px; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.94); border:none; color:var(--ink); display:grid; place-items:center; cursor:pointer; box-shadow:var(--shadow-sm); }
.img-viewer-close svg{ width:20px; height:20px; }
.hist-audio{ width:100%; }

/* Placeholder reorder drawer (sits above the audit panel) — same specificity bump as hist-drawer. */
.bp-drawer.reorder-drawer{ z-index:1100; }
.reorder-ph{ text-align:center; padding:24px 8px; display:flex; flex-direction:column; align-items:center; gap:12px; }
.reorder-ph-icon{ width:64px; height:64px; border-radius:16px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; }
.reorder-ph-icon svg{ width:30px; height:30px; }
.reorder-ph-ttl{ margin:0; font-family:'Outfit'; font-weight:800; font-size:20px; }
.reorder-ph-item{ margin:0; font-family:'Outfit'; font-weight:800; font-size:15px; color:var(--sky-deep); }
.reorder-ph-note{ margin:0; font-size:13px; color:var(--ink-soft); max-width:36ch; line-height:1.5; }

@media (max-width:520px){
  .ai-yn{ font-size:13px; gap:6px; padding:8px 4px; }
}

/* Summary */
.summary-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:14px; margin-top:14px;
}
.summary-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:14px; display:flex; flex-direction:column; gap:10px; }
.summary-card-h{ display:flex; align-items:center; gap:10px; }
.summary-card-icon{ width:30px; height:30px; border-radius:8px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; }
.summary-card-icon svg{ width:16px; height:16px; }
.summary-card-name{ font-family:'Outfit'; font-weight:800; font-size:14px; }
.summary-card-pie{ width:96px; height:96px; }
.summary-card-counts{ font-size:13px; font-weight:800; color:var(--ink-soft); }
.summary-card-fails{ list-style:disc; padding-left:18px; margin:0; font-size:12px; font-weight:700; }
.summary-card-fails li{ color:var(--coral-deep); }
.summary-card-fails li[data-tone="warn"]{ color:#A87014; }
.summary-card-fails li[data-tone="bad"]{ color:var(--coral-deep); }
.sd-signoff{ margin-top:20px; padding:18px; display:flex; flex-direction:column; gap:10px; }
.sd-signoff .wz-label{ margin-bottom:0; }

/* Asset-order modal */
.ao-overlay{
  position:fixed; inset:0; background:rgba(11,79,134,.35);
  display:grid; place-items:center; z-index:90;
  opacity:0; transition:opacity .2s;
}
.ao-overlay.open{ opacity:1; }
.ao-modal{
  background:#fff; border-radius:18px; width:min(560px, calc(100% - 24px)); max-height:88vh; overflow:auto;
  transform:translateY(12px); transition:transform .2s; box-shadow:var(--shadow-md);
}
.ao-overlay.open .ao-modal{ transform:none; }
.ao-h{ display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--line); }
.ao-h h2{ margin:0; font-family:'Outfit'; font-weight:800; font-size:18px; }
.ao-form{ padding:16px 18px; display:flex; flex-direction:column; gap:14px; }
.ao-form .wz-grid{ grid-template-columns:repeat(2, 1fr); }
@media (max-width:560px){ .ao-form .wz-grid{ grid-template-columns:1fr; } }
.ao-foot{ display:flex; justify-content:flex-end; gap:10px; }
.ao-status{ font-size:12px; font-weight:700; color:var(--ink-soft); }

/* Homepage / programs PNG */
.programs-side .program-row .av.prog-img{ padding:0; overflow:hidden; }
.programs-side .program-row .av.prog-img img{ width:100%; height:100%; object-fit:cover; display:block; }

/* Desktop: bigger thumb, bigger name, age-range moves to the right of the name on the same row. */
@media (min-width:1025px){
  .programs-side .program-row{ padding:16px 18px; gap:16px; }
  .programs-side .program-row .av{ width:64px; height:64px; flex:none; }
  .programs-side .program-row > div{
    display:flex; flex-direction:row; align-items:baseline;
    gap:12px; flex-wrap:wrap; min-width:0;
  }
  .programs-side .program-row .nm{ font-size:22px; }
  .programs-side .program-row .ag{
    font-size:21px; margin-top:0;
    letter-spacing:.04em; text-transform:none;
    color:var(--sky-deep); font-weight:700;
    font-family: 'Outfit';
  }
}
.prog-hero-img{ overflow:hidden; }
.prog-hero-img img{ width:100%; height:auto; display:block; border-radius:inherit; }
/* Desktop: programs-page hero is landscape, not portrait (overrides .hero-img 3/4). */
@media (min-width:1025px){
  .prog-hero .hero-img.prog-hero-img{ aspect-ratio: 16/10; }
  .prog-hero .hero-img.prog-hero-img img{ width:100%; height:100%; object-fit:cover; }
}

/* Per-school program tabs */
.sd-programs{ padding:14px; display:flex; flex-direction:column; gap:12px; grid-column:1 / -1; }
.sd-programs-h .ttl{ font-family:'Outfit'; font-weight:800; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-deep); }
.sd-prog-tabs{ display:flex; gap:8px; border-bottom:1px solid var(--line); flex-wrap:wrap; }
.sd-prog-tab{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 12px 6px 6px; border-radius:12px 12px 0 0;
  background:var(--line-soft); border:1px solid transparent;
  font-family:'Outfit'; font-weight:800; color:var(--ink-soft);
  transition:background .15s, color .15s, border-color .15s;
  margin-bottom:-1px;
}
.sd-prog-tab.on{ background:#fff; color:var(--ink); border-color:var(--line); border-bottom-color:#fff; }
.sd-prog-thumb{ width:34px; height:34px; border-radius:8px; overflow:hidden; background:#fff; flex:none; display:grid; place-items:center; }
.sd-prog-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.sd-prog-tab-meta{ display:flex; flex-direction:column; gap:0; min-width:0; line-height:1.15; }
.sd-prog-tab-name{ font-size:13px; }
.sd-prog-tab-age{ font-size:11px; color:var(--ink-soft); font-weight:700; }
.sd-prog-panel{ padding:14px 4px; display:flex; flex-direction:column; gap:8px; }
.sd-prog-panel:not(.on){ display:none; }
.sd-prog-counts{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-soft); font-weight:700; }
.sd-prog-subh{ margin:8px 0 0; font-family:'Outfit'; font-weight:800; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--sky-deep); }
.sd-prog-list{ list-style:disc; padding-left:18px; margin:0; font-size:13px; color:var(--ink); }
.sd-prog-list li{ margin:2px 0; }
.sd-prog-list:empty::before{ content:"—"; color:var(--ink-soft); font-style:italic; }
.asset-order-form{ padding:18px; display:flex; flex-direction:column; gap:14px; }
.asset-order-form .wz-grid{ grid-template-columns:repeat(2, 1fr); }
@media (max-width:600px){ .asset-order-form .wz-grid{ grid-template-columns:1fr; } }

/* History modal (still bottom-sheet) + Blueprint drawer (right-side full-height) */
.hist-overlay{
  position:fixed; inset:0; background:rgba(11,79,134,.35);
  display:grid; place-items:end center; z-index:80; opacity:0; transition:opacity .2s;
  padding:0;
}
.hist-overlay.open{ opacity:1; }
.hist-modal{
  background:#fff; border-top-left-radius:24px; border-top-right-radius:24px;
  width:min(560px, 100%); max-height:88vh; overflow:auto;
  transform:translateY(20px); transition:transform .2s;
  box-shadow:var(--shadow-md);
}
.hist-overlay.open .hist-modal{ transform:none; }

.bp-drawer{
  position:fixed; inset:0; background:rgba(11,79,134,.35);
  z-index:1000; opacity:0; transition:opacity .2s;
  display:flex; justify-content:flex-end;
}
.bp-drawer.open{ opacity:1; }
.bp-drawer-sheet{
  background:#fff;
  width:min(560px, 100%); height:100%;
  display:flex; flex-direction:column;
  transform:translateX(40px); transition:transform .25s;
  box-shadow:-8px 0 32px -12px rgba(11,79,134,.25);
}
.bp-drawer.open .bp-drawer-sheet{ transform:none; }
.bp-drawer-tabs{ display:flex; gap:2px; padding:0 12px; border-bottom:1px solid var(--line); overflow-x:auto; flex:none; }
.bp-drawer-tabs:empty{ display:none; }
.bp-drawer-tab{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px; font-family:'Outfit'; font-weight:700; font-size:13px;
  color:var(--ink-soft); background:transparent; border-bottom:3px solid transparent;
  white-space:nowrap; transition:color .15s, border-color .15s;
}
.bp-drawer-tab-thumb{ width:24px; height:24px; border-radius:6px; object-fit:cover; flex:none; }
.bp-drawer-tab-age{ font-size:11px; color:var(--ink-soft); font-weight:700; }
.bp-drawer-tab:hover{ color:var(--ink); }
.bp-drawer-tab.on{ color:var(--sky-deep); border-bottom-color:var(--sky); }
.bp-drawer-body{ flex:1; overflow:auto; padding:18px 20px; }
.bpd-tab-head{ display:flex; align-items:center; gap:10px; margin:0 0 14px; flex-wrap:wrap; }
.bpd-tab-head h3{ margin:0; font-family:'Outfit'; font-weight:800; font-size:18px; flex:1; min-width:0; }
.bpd-tab-when{ font-size:12px; color:var(--ink-soft); font-weight:700; }
.bpd-entry-h{ display:flex; align-items:center; gap:8px; }
.bp-drawer-audio{ width:100%; }
@media (max-width:560px){ .bp-drawer-sheet{ width:100%; } }
.hist-h, .bp-drawer-h{ display:flex; align-items:center; gap:10px; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--line); position:sticky; top:0; background:#fff; }
.hist-ttl, .bp-drawer-ttl{ font-family:'Outfit'; font-weight:800; font-size:16px; color:var(--ink); text-transform:capitalize; }
.bp-drawer-ttl{ flex:1; min-width:0; font-size:21px; }
.bp-drawer-icon{ width:36px; height:36px; border-radius:10px; background:var(--sky-soft); color:var(--sky-deep); display:grid; place-items:center; flex:none; }
.bp-drawer-icon[hidden]{ display:none; }
.bp-drawer-icon svg{ width:20px; height:20px; }
.hist-body, .bp-drawer-body{ padding:18px 20px; }
.hist-foot{ display:flex; justify-content:space-between; align-items:center; padding:12px 20px; border-top:1px solid var(--line); }
.hist-pos{ font-size:12px; color:var(--ink-soft); font-weight:700; }
.hist-slide{ display:flex; flex-direction:column; gap:10px; }
.hist-when{ font-size:12px; font-weight:700; color:var(--ink-soft); }
.hist-status{ display:inline-block; padding:3px 10px; border-radius:99px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; width:max-content; }
.hist-status[data-tone="ok"]{ background:rgba(63,178,142,.16); color:var(--mint); }
.hist-status[data-tone="warn"]{ background:rgba(255,200,87,.18); color:#A87014; }
.hist-status[data-tone="bad"]{ background:rgba(242,106,86,.16); color:var(--coral-deep); }
.hist-note{ font-size:14px; color:var(--ink); }
.hist-empty{ color:var(--ink-soft); font-weight:700; }
.hist-photos{ display:flex; gap:8px; flex-wrap:wrap; }
.hist-photos img{ width:100px; height:100px; border-radius:10px; object-fit:cover; border:1px solid var(--line); }
.hist-audio{ width:100%; }

.bp-drawer-row{ margin-bottom:18px; }
.bp-drawer-row h4{ margin:0 0 8px; font-family:'Outfit'; font-weight:800; font-size:14px; }
.bp-drawer-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.bp-drawer-list li{ padding:10px; border:1px solid var(--line); border-radius:10px; display:flex; flex-direction:column; gap:6px; }
.bp-drawer-when{ font-size:11px; font-weight:700; color:var(--ink-soft); }
.bp-drawer-status{ font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; padding:2px 8px; border-radius:99px; width:max-content; }
.bp-drawer-status[data-tone="ok"]{ background:rgba(63,178,142,.16); color:var(--mint); }
.bp-drawer-status[data-tone="bad"]{ background:rgba(242,106,86,.16); color:var(--coral-deep); }
.bp-drawer-status[data-tone="warn"]{ background:rgba(255,200,87,.18); color:#A87014; }
.bp-drawer-note{ font-size:13px; color:var(--ink); }
.bp-drawer-photos{ display:flex; gap:6px; flex-wrap:wrap; }
.bp-drawer-photos img{ width:64px; height:64px; border-radius:8px; object-fit:cover; border:1px solid var(--line); }
.bp-drawer-empty{ color:var(--ink-soft); font-size:13px; font-weight:700; }

/* Language pill */
.lang-toggle{ display:inline-flex; border:1px solid var(--line); border-radius:99px; overflow:hidden; }
.lang-toggle .lang-opt{ padding:7px 14px; font-family:'Outfit'; font-weight:800; font-size:12px; color:var(--ink-soft); background:#fff; }
.lang-toggle .lang-opt.on{ background:var(--sky-deep); color:#fff; }
.topbar-lang{ margin-right:4px; height:auto; align-items:center; }
.topbar-lang .lang-opt{ padding:9px 12px; font-size:12px; min-height:38px; }
@media (max-width:760px){ .topbar-lang{ margin-right:0; } .topbar-lang .lang-opt{ padding:9px 10px; font-size:12px; min-height:40px; } }
@media (max-width:600px){ .topbar-lang .lang-opt{ padding:8px 9px; min-height:38px; } }

/* mr-status reuse for asset order list */
.mr-id{ font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--ink-soft); }
.mr-status{ display:inline-block; padding:3px 10px; border-radius:99px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; }
.mr-status[data-tone="ok"]{ background:rgba(63,178,142,.16); color:var(--mint); }
.mr-status[data-tone="warn"]{ background:rgba(255,200,87,.18); color:#A87014; }
.mr-status[data-tone="bad"]{ background:rgba(242,106,86,.16); color:var(--coral-deep); }
.mr-status[data-tone="sky"]{ background:var(--sky-soft); color:var(--sky-deep); }


/* ============================================================
   Inventory severity metric (school-card overlay)
   Colors keyed off [data-severity] so PHP/JS never ship hex.
   Single source of truth in PHP: KK\View\Severity.
   ============================================================ */
:root{
  --sev-low:    #6FB5E0;   /* sky-tint  */
  --sev-medium: #FFC857;   /* sun       */
  --sev-high:   #F39A4A;   /* amber     */
  --sev-urgent: #F26A56;   /* coral     */
}
.school-card-issues{ display:flex; flex-direction:column; gap:6px; padding:10px 12px 12px; }
.school-card-issues-head{ display:flex; align-items:baseline; gap:6px; }
.school-card-issues-count{ font-family:'Outfit'; font-weight:800; font-size:22px; color:var(--ink); line-height:1; }
.school-card-issues-label{ font-size:12px; font-weight:600; color:var(--ink-soft); text-transform:lowercase; }
.school-card-issues[data-issues-total="0"] .school-card-issues-count{ color:var(--mint); }

.school-card-sev-bar{
  display:flex; height:8px; width:100%; border-radius:99px; overflow:hidden;
  background:var(--line-soft); border:1px solid var(--line);
}
.school-card-sev-seg{ display:block; height:100%; }
.school-card-sev-seg[data-severity="low"]   { background:var(--sev-low); }
.school-card-sev-seg[data-severity="medium"]{ background:var(--sev-medium); }
.school-card-sev-seg[data-severity="high"]  { background:var(--sev-high); }
.school-card-sev-seg[data-severity="urgent"]{ background:var(--sev-urgent); }

.school-card-sev-legend{
  display:grid; grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:2px 8px; font-size:11.5px; font-weight:600; color:var(--ink-soft);
}
.school-card-sev-chip{ display:inline-flex; align-items:center; gap:6px; min-width:0; }
.school-card-sev-dot{
  display:inline-block; width:8px; height:8px; border-radius:50%; flex:0 0 auto;
}
.school-card-sev-chip[data-severity="low"]    .school-card-sev-dot{ background:var(--sev-low); }
.school-card-sev-chip[data-severity="medium"] .school-card-sev-dot{ background:var(--sev-medium); }
.school-card-sev-chip[data-severity="high"]   .school-card-sev-dot{ background:var(--sev-high); }
.school-card-sev-chip[data-severity="urgent"] .school-card-sev-dot{ background:var(--sev-urgent); }
.school-card-sev-name{ flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.school-card-sev-n{ font-weight:800; color:var(--ink); }

/* Inventory "Overall Levels" gauge (replaces the stacked severity bar) */
.school-card-levels{ display:flex; flex-direction:column; align-items:center; gap:6px; width:124px; flex:none; margin-left:auto; padding:6px 4px; }
.sc-gauge{ position:relative; width:110px; }
.sc-gauge-svg{ display:block; width:110px; height:auto; overflow:visible; }
.sc-gauge-track{ fill:none; stroke:var(--line); stroke-width:9; stroke-linecap:round; }
.sc-gauge-fill{ fill:none; stroke-width:9; stroke-linecap:round; transition:stroke-dasharray .35s ease; }
.sc-gauge-fill[data-severity="low"]   { stroke:var(--sev-low); }
.sc-gauge-fill[data-severity="medium"]{ stroke:var(--sev-medium); }
.sc-gauge-fill[data-severity="high"]  { stroke:var(--sev-high); }
.sc-gauge-fill[data-severity="urgent"]{ stroke:var(--sev-urgent); }
.sc-gauge-val{ position:absolute; left:0; right:0; bottom:0; text-align:center; line-height:1.04; pointer-events:none; }
.sc-gauge-val b{ display:block; font-family:'Outfit'; font-weight:800; font-size:21px; color:var(--ink); }
.sc-gauge-val span{ font-size:9px; font-weight:800; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.04em; }
.sc-levels{ display:flex; flex-direction:column; align-items:center; gap:1px; width:100%; }
.sc-level{ font-size:12px; font-weight:700; color:var(--ink-soft); }
.sc-level b{ color:var(--ink); }
.sc-level .sc-level-name{ font-weight:800; }
.sc-level[data-severity="low"]    .sc-level-name{ color:var(--sev-low); }
.sc-level[data-severity="medium"] .sc-level-name{ color:var(--sev-medium); }
.sc-level[data-severity="high"]   .sc-level-name{ color:var(--sev-high); }
.sc-level[data-severity="urgent"] .sc-level-name{ color:var(--sev-urgent); }
.sc-level-none{ color:var(--mint); font-weight:800; }

/* ---- Inventory data-source toggle (debug visibility) ---- */
.data-source-badge{
  display:flex; align-items:center; flex-wrap:wrap; gap:10px;
  margin:0 0 14px; padding:8px 12px;
  background:var(--sky-soft); border:1px solid var(--line);
  border-radius:99px; font-size:12px; color:var(--ink-soft);
}
.data-source-label{ font-weight:600; text-transform:uppercase; letter-spacing:.08em; }
.data-source-name{ color:var(--ink); font-family:'Outfit'; font-weight:800; }
.data-source-toggle{ display:inline-flex; gap:4px; margin-left:auto; }
.data-source-opt{
  padding:4px 10px; border-radius:99px;
  font-family:'Outfit'; font-weight:700; font-size:11.5px;
  background:#fff; border:1px solid var(--line); color:var(--ink-soft);
}
.data-source-opt.on{ background:var(--sky-deep); border-color:var(--sky-deep); color:#fff; }

/* ============================================================
   Timesheets — weekly hours tool (Employee Portal)
   ============================================================ */
.ts-page{ padding-top:6px; }
.ts-view[hidden]{ display:none; }

/* user bar + New/Edit */
.ts-bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin:6px 0 16px; }
.ts-user{ display:flex; align-items:center; gap:12px; min-width:0; }
.ts-user-av{ width:46px; height:46px; border-radius:50%; background:var(--sky-deep); color:#fff; display:grid; place-items:center; font-family:'Outfit'; font-weight:800; font-size:16px; flex:none; }
.ts-user-meta{ display:flex; flex-direction:column; min-width:0; }
.ts-user-name{ font-family:'Outfit'; font-weight:800; font-size:20px; color:var(--ink); line-height:1.1; }
.ts-user-sub{ font-size:12px; font-weight:700; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.06em; }
.ts-bar-actions{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }

/* icon + label buttons */
.ts-ibtn{ display:inline-flex; align-items:center; gap:7px; }
.ts-ibtn svg{ flex:none; }

/* view toggle (Compact / Expand) — mobile only; desktop has room for all day columns */
.ts-viewtog{ display:none; align-items:center; gap:2px; background:var(--line-soft); border:1px solid var(--line); border-radius:11px; padding:3px; }
.ts-viewtog-ic{ display:grid; place-items:center; width:26px; color:var(--ink-soft); }
.ts-vt{ font-family:'Outfit'; font-weight:800; font-size:12px; letter-spacing:.03em; color:var(--ink-soft); background:transparent; border:none; padding:7px 12px; border-radius:8px; cursor:pointer; }
.ts-vt.on{ background:#fff; color:var(--sky-deep); box-shadow:0 1px 3px rgba(11,79,134,.18); }

/* table */
.ts-card{ padding:0; overflow:hidden; }
.ts-table-wrap{ overflow-x:auto; }
.ts-table{ width:100%; border-collapse:collapse; font-size:13.5px; min-width:640px; }
.ts-table th, .ts-table td{ padding:11px 10px; text-align:center; white-space:nowrap; }
.ts-table thead th{ font-family:'Outfit'; font-weight:800; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--sky-deep); background:var(--sky-soft); border-bottom:1px solid var(--line); }
.ts-th-week, .ts-td-week, .ts-tf-label{ text-align:left; }
.ts-td-week{ font-family:'Outfit'; font-weight:800; color:var(--ink); }
.ts-table tbody td{ border-bottom:1px solid var(--line-soft); color:var(--ink); font-weight:700; }
.ts-row{ cursor:pointer; transition:background .12s; }
.ts-row:hover td{ background:var(--sky-soft); }
.ts-row-cur .ts-td-week::after{ content:"Current"; margin-left:8px; font:800 9px 'Outfit'; letter-spacing:.08em; text-transform:uppercase; color:#fff; background:var(--mint); padding:2px 7px; border-radius:99px; vertical-align:middle; }
/* accordion (+) column */
.ts-th-acc, .ts-td-acc, .ts-tf-acc{ width:34px; padding-left:8px; padding-right:0; }
.ts-acc-btn{ width:24px; height:24px; border-radius:7px; background:var(--sky-soft); color:var(--sky-deep); border:1px solid var(--line); font-family:'Outfit'; font-weight:800; font-size:16px; line-height:1; display:grid; place-items:center; cursor:pointer; }
.ts-acc-btn:hover{ background:#fff; border-color:var(--sky); }
.ts-acc-btn.on{ background:var(--sky-deep); color:#fff; border-color:var(--sky-deep); }
.ts-acc-row > .ts-acc-cell{ padding:14px; background:#F5F9FC; border-bottom:1px solid var(--line); }
.ts-acc-cell .card{ box-shadow:none; border:1px solid var(--line); }
.ts-table-expand{ min-width:0; }

.ts-th-reg, .ts-td-reg{ border-left:1px solid var(--line); color:var(--ink-soft); }
.ts-th-ot, .ts-td-ot{ color:var(--ink-soft); }
.ts-td-ot.ts-ot-on, .ts-td-day.ts-ot-on{ color:#C2902A; font-weight:800; }
.ts-td-total, .ts-th-total{ font-weight:800; color:var(--sky-deep); border-left:1px solid var(--line); }
.ts-row-sub .ts-td-week::after{ content:"Submitted"; margin-left:8px; font:800 9px 'Outfit'; letter-spacing:.08em; text-transform:uppercase; color:#fff; background:var(--sky-deep); padding:2px 7px; border-radius:99px; vertical-align:middle; }
.ts-weekend{ background:rgba(11,79,134,.045); }
.ts-holiday{ background:rgba(232,165,43,.14); color:#A87014 !important; }
.ts-empty{ padding:28px; color:var(--ink-soft); font-weight:700; font-style:italic; }
/* footer totals */
.ts-table tfoot td{ border-top:2px solid var(--line); background:#FAFCFE; font-family:'Outfit'; font-weight:800; color:var(--ink); }
.ts-tf-label{ color:var(--ink-soft); text-transform:uppercase; font-size:11px; letter-spacing:.08em; }
.ts-tf-reg{ border-left:1px solid var(--line); color:var(--ink-soft); }
.ts-tf-ot{ color:#C2902A; }
.ts-tf-grand{ color:var(--sky-deep); border-left:1px solid var(--line); font-size:15px; }

/* entry — week nav */
.ts-entry-head{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; padding:14px 16px; margin-bottom:14px; }
.ts-nav{ display:flex; align-items:center; gap:10px; }
.ts-nav-btn{ width:38px; height:38px; border-radius:10px; background:var(--sky-soft); color:var(--sky-deep); border:1px solid var(--line); font-size:20px; font-weight:800; line-height:1; cursor:pointer; display:grid; place-items:center; }
.ts-nav-btn:hover{ background:#fff; border-color:var(--sky); }
.ts-nav-range{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex:1 1 auto; font-family:'Outfit'; font-weight:800; font-size:18px; color:var(--ink); min-width:240px; }
.ts-head-tools{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ts-jump{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.05em; }
.ts-jump input{ font-family:'Outfit'; font-weight:700; font-size:13px; padding:8px 10px; border:1px solid var(--line); border-radius:9px; color:var(--ink); background:#fff; }

.ts-sub-badge{ font:800 10px 'Outfit'; letter-spacing:.06em; text-transform:uppercase; color:#fff; background:var(--sky-deep); padding:3px 9px; border-radius:99px; vertical-align:middle; margin-left:8px; }

/* entry — day rows */
.ts-days{ display:flex; flex-direction:column; padding:6px 6px; }
.ts-days-head{ display:flex; align-items:center; gap:14px; padding:10px 14px; margin-bottom:4px; font:800 11px 'Outfit'; letter-spacing:.08em; text-transform:uppercase; color:var(--sky-deep); background:var(--sky-soft); border-bottom:1px solid var(--line); border-radius:8px; }
.ts-dh-day{ flex:1 1 auto; min-width:0; }
.ts-dh-times{ width:240px; text-align:center; flex:none; }
.ts-dh-hours{ width:148px; text-align:center; flex:none; }
.ts-day{ display:flex; align-items:center; gap:14px; padding:14px; border-radius:10px; }
.ts-day + .ts-day{ border-top:2px solid var(--line); }   /* pronounced day divider — groups the days */
.ts-day.ts-weekend{ background:rgba(11,79,134,.045); }
.ts-day.ts-holiday{ background:rgba(232,165,43,.12); }
.ts-day-label{ display:flex; align-items:center; gap:10px; min-width:0; flex:1 1 auto; flex-wrap:wrap; }
.ts-day-name{ font-family:'Outfit'; font-weight:800; font-size:15px; color:var(--ink); min-width:84px; }
.ts-day-date{ font-size:13px; font-weight:700; color:var(--ink-soft); }
.ts-holiday-badge{ font-family:'Outfit'; font-weight:800; font-size:11px; color:#fff; background:#C2902A; padding:3px 10px; border-radius:99px; }
.ts-copy{ display:inline-flex; align-items:center; gap:5px; font-family:'Outfit'; font-weight:800; font-size:11px; color:var(--sky-deep); background:var(--sky-soft); border:1px solid var(--line); border-radius:8px; padding:4px 9px; cursor:pointer; }
.ts-copy svg{ flex:none; }
.ts-copy:hover{ background:#fff; border-color:var(--sky); }
.ts-copy-hide{ display:none; }
.ts-copy-short{ display:none; }
.ts-locked{ opacity:.96; }
.ts-locked .ts-time, .ts-locked .ts-hours, .ts-locked .ts-step, .ts-sign input:disabled{ color:var(--ink-soft); cursor:not-allowed; }
.ts-locked .ts-stepper{ opacity:.6; }

/* entry — start/end clock fields */
.ts-times{ display:inline-flex; align-items:center; gap:6px; width:240px; flex:none; justify-content:center; }
.ts-time{ font-family:'Outfit'; font-weight:700; font-size:13px; padding:7px 8px; border:1px solid var(--line); border-radius:9px; color:var(--ink); background:#fff; width:120px; box-sizing:border-box; }
.ts-time:focus{ outline:none; border-color:var(--sky); }
.ts-time-sep{ color:var(--ink-soft); font-weight:800; }

/* entry — stepper */
.ts-stepper{ display:inline-flex; align-items:center; gap:8px; background:var(--line-soft); border-radius:12px; padding:4px; flex:none; width:148px; justify-content:center; }
.ts-step{ width:36px; height:36px; border-radius:9px; background:#fff; color:var(--sky-deep); font-family:'Outfit'; font-weight:800; font-size:20px; line-height:1; display:grid; place-items:center; box-shadow:0 1px 2px rgba(11,79,134,.14); cursor:pointer; }
.ts-step:hover{ background:var(--sky-soft); }
.ts-hours{ width:56px; text-align:center; font-family:'Outfit'; font-weight:800; font-size:17px; color:var(--ink); border:none; background:transparent; outline:none; padding:0; }
/* per-day overtime highlight — once the week's running total passes 40h */
.ts-day-ot .ts-hours{ color:#C2902A; }
.ts-day-ot .ts-day-name{ color:#C2902A; }

/* entry — weekly summary (regular / overtime / total) */
.ts-summary{ display:flex; gap:0; margin-top:14px; padding:0; overflow:hidden; }
.ts-sum-cell{ flex:1 1 0; display:flex; flex-direction:column; align-items:center; gap:4px; padding:16px 12px; }
.ts-sum-cell + .ts-sum-cell{ border-left:1px solid var(--line-soft); }
.ts-sum-k{ font:700 11px 'Outfit'; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft); }
.ts-sum-v{ font-family:'Outfit'; font-weight:800; font-size:24px; color:var(--ink); }
.ts-sum-ot .ts-sum-v{ color:#C2902A; }
.ts-sum-tot{ background:var(--sky-soft); }
.ts-sum-tot .ts-sum-v{ color:var(--sky-deep); }

/* entry — signatures */
.ts-sign{ margin-top:14px; padding:18px; }
.ts-sign-title{ font-family:'Outfit'; font-weight:800; font-size:14px; color:var(--ink); margin:0 0 14px; text-transform:uppercase; letter-spacing:.05em; }
.ts-sign-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.ts-sign-field{ display:flex; flex-direction:column; gap:6px; }
.ts-sign-field span{ font:700 12px 'Outfit'; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); }
.ts-sign-field input{ font-family:'Outfit'; font-weight:700; font-size:15px; padding:10px 12px; border:1px solid var(--line); border-radius:10px; color:var(--ink); background:#fff; }
.ts-sign-field input:focus{ outline:none; border-color:var(--sky); }
.ts-sign-err{ display:none; font:700 11px 'Outfit'; color:#C0392B; }
.ts-sign-field.ts-err input{ border-color:#C0392B; background:#FFF6F6; }
.ts-sign-field.ts-err .ts-sign-err{ display:block; color: #d64732; }
@keyframes ts-jiggle{ 0%,100%{ transform:translateX(0); } 15%{ transform:translateX(-6px); } 30%{ transform:translateX(6px); } 45%{ transform:translateX(-5px); } 60%{ transform:translateX(4px); } 75%{ transform:translateX(-2px); } }
.ts-jiggle{ animation:ts-jiggle .42s ease; }

/* custom confirm modal */
.ts-modal-ov{ position:fixed; inset:0; background:rgba(11,30,50,.5); display:grid; place-items:center; z-index:1000; padding:20px; }
.ts-modal{ background:#fff; border-radius:16px; width:100%; max-width:380px; box-shadow:0 20px 50px -12px rgba(11,30,50,.55); overflow:hidden; }
.ts-modal-title{ font-family:'Outfit'; font-weight:800; font-size:18px; color:var(--ink); margin:0; padding:18px 20px 6px; }
.ts-modal-body{ padding:6px 20px 14px; }
.ts-modal-msg{ margin:6px 0; font-size:15px; font-weight:700; color:var(--ink); }
.ts-modal-sum{ display:flex; flex-direction:column; }
.ts-modal-row{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:9px 0; border-bottom:1px solid var(--line-soft); font-size:14px; }
.ts-modal-row:last-child{ border-bottom:none; }
.ts-modal-row span{ color:var(--ink-soft); font-weight:700; }
.ts-modal-row b{ font-family:'Outfit'; font-weight:800; color:var(--ink); }
.ts-modal-ot b{ color:#C2902A; }
.ts-modal-tot b{ color:var(--sky-deep); font-size:16px; }
.ts-modal-foot{ display:flex; gap:10px; padding:14px 20px 18px; }
.ts-modal-btn{ flex:1 1 0; display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:'Outfit'; font-weight:800; font-size:14px; padding:12px; border-radius:11px; border:none; cursor:pointer; }
.ts-modal-cancel{ background:#FDECEC; color:#C0392B; }
.ts-modal-cancel:hover{ background:#F8D7D7; }
.ts-modal-ok{ background:var(--mint); color:#fff; }
.ts-modal-ok:hover{ filter:brightness(.95); }
.ts-modal-ok:focus-visible, .ts-modal-cancel:focus-visible{ outline:2px solid var(--sky); outline-offset:2px; }

/* print preview modal */
.ts-print-ov{ position:fixed; inset:0; background:rgba(11,30,50,.5); display:grid; place-items:center; z-index:1100; padding:20px; }
.ts-print-modal{ background:#fff; border-radius:14px; width:100%; max-width:780px; max-height:92vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 20px 50px -12px rgba(11,30,50,.55); }
.ts-print-bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:13px 18px; border-bottom:1px solid var(--line); }
.ts-print-bar-t{ font-family:'Outfit'; font-weight:800; font-size:16px; color:var(--ink); }
.ts-print-bar-actions{ display:flex; gap:10px; }
.ts-print-bar-actions .ts-modal-btn{ flex:none; padding:9px 16px; }
.ts-print-scroll{ overflow:auto; padding:24px; background:#E9EEF2; }

/* the printable sheet — grayscale, modeled on the paper time card */
.ts-print-sheet{ background:#fff; color:#000; width:7.5in; max-width:100%; margin:0 auto; padding:30px 32px; font-family:'Nunito', Arial, sans-serif; box-shadow:0 2px 10px rgba(0,0,0,.18); }
.pf-head{ display:flex; align-items:center; gap:16px; border-bottom:2px solid #000; padding-bottom:12px; margin-bottom:16px; }
.pf-logo{ height:52px; filter:grayscale(1) contrast(1.05); }
.pf-title{ font-family:'Outfit'; font-weight:800; font-size:22px; letter-spacing:.08em; text-transform:uppercase; color:#000; margin-left:auto; }
.pf-meta{ display:flex; justify-content:space-between; gap:24px; margin-bottom:16px; }
.pf-col{ display:flex; flex-direction:column; gap:8px; }
.pf-field{ display:flex; align-items:flex-end; gap:8px; font-size:13px; }
.pf-field span{ font-weight:800; text-transform:uppercase; letter-spacing:.04em; white-space:nowrap; }
.pf-field b{ border-bottom:1px solid #000; min-width:130px; font-weight:700; padding:0 4px 1px; }
.pf-table{ width:100%; border-collapse:collapse; margin-bottom:24px; }
.pf-table th, .pf-table td{ border:1px solid #000; padding:7px 10px; font-size:13px; text-align:center; height:14px; }
.pf-table th{ text-transform:uppercase; font-family:'Outfit'; font-weight:800; letter-spacing:.05em; background:#ededed; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.pf-date{ text-align:left !important; font-weight:700; white-space:nowrap; }
.pf-tf{ text-align:left !important; font-weight:800; text-transform:uppercase; }
.pf-table tfoot td{ font-weight:800; background:#f4f4f4; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.pf-sign{ display:flex; gap:30px; margin-top:34px; }
.pf-sign-col{ flex:1 1 0; }
.pf-sign-line{ border-bottom:1px solid #000; min-height:26px; font-family:'Nunito'; font-size:15px; padding:0 4px 2px; }
.pf-sign-col span{ display:block; margin-top:5px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }

@media print {
  body > *:not(.ts-print-ov){ display:none !important; }
  .ts-print-ov{ position:static; inset:auto; background:none; padding:0; display:block; overflow:visible; }
  .ts-print-modal{ box-shadow:none; max-width:none; width:auto; max-height:none; border-radius:0; overflow:visible; }
  .ts-print-bar{ display:none !important; }
  .ts-print-scroll{ overflow:visible; padding:0; background:none; }
  .ts-print-sheet{ width:auto; box-shadow:none; padding:0; margin:0; }
  @page{ size:portrait; margin:0.5in; }
}

/* entry — footer */
.ts-entry-foot{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:16px; flex-wrap:wrap; }

@media (max-width:640px){
  .ts-days-head{ display:none; }
  .ts-days{ padding:0; }
  .ts-day{ flex-wrap:wrap; gap:10px; padding:0 0 12px; border-radius:0; }
  .ts-day + .ts-day{ border-top:3px solid var(--line); }
  /* darker, full-width day header bar — groups each day */
  .ts-day-label{ flex:1 1 100%; gap:8px; padding:9px 12px; background:rgba(11,79,134,.12); border-bottom:1px solid var(--line); }
  .ts-day.ts-holiday .ts-day-label{ background:rgba(232,165,43,.22); }
  .ts-day-name{ min-width:0; color:var(--sky-deep); }
  .ts-day-date{ color:var(--ink); }
  .ts-copy{ margin-left:auto; }
  .ts-copy-long{ display:none; }
  .ts-copy-short{ display:inline; }
  /* times + hour stepper share one row */
  .ts-times{ width:auto; flex:1 1 auto; gap:5px; padding:0 12px; }
  .ts-time{ flex:1 1 0; width:auto; min-width:0; }
  .ts-stepper{ width:auto; flex:none; gap:3px; padding:3px; margin-right:12px; }
  .ts-step{ width:32px; height:32px; font-size:18px; }
  .ts-hours{ width:46px; font-size:16px; }
  .ts-sign-grid{ grid-template-columns:1fr; }
  /* table: left-align week + replace "Current" pill with a green dot */
  .ts-td-week{ text-align:left; }
  .ts-row-cur .ts-td-week::after{ content:""; display:inline-block; width:8px; height:8px; padding:0; margin-left:7px; border-radius:50%; background:var(--mint); vertical-align:middle; }
}
@media (max-width:560px){
  .ts-nav-range{ min-width:0; font-size:16px; text-align:left; }
  .ts-entry-head{ gap:10px; }
}
