/* Lakeview Montessori School — shared stylesheet for all pages */
:root{
  --white:#FFFFFF;
  --black:#000000;
  --blue:#4F81BD;
  --green:#9BBB59;
  --purple:#633A75;
  --navy:#004F78;
  --teal:#6295A8;

  --bg: #FFFFFF;
  --ink: #111111;
  --muted: #3a3a3a;
  --surface: #ffffff;
  --surface-2: color-mix(in srgb, var(--teal) 10%, white);
  --surface-3: color-mix(in srgb, var(--green) 10%, white);
  --border: color-mix(in srgb, var(--navy) 14%, white);

  --shadow: 0 10px 28px rgba(0,0,0,.08);
  --radius: 18px;
  --radius-sm: 12px;

  --container: 1120px;
  --pad: 20px;

  --focus: 0 0 0 3px color-mix(in srgb, var(--blue) 35%, white);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.7;
  color:var(--ink);
  background:
    radial-gradient(1000px 500px at 20% -10%, color-mix(in srgb, var(--green) 18%, white) 0%, transparent 60%),
    radial-gradient(900px 480px at 90% 0%, color-mix(in srgb, var(--blue) 18%, white) 0%, transparent 55%),
    var(--bg);
}
img{max-width:100%; height:auto}

/* Accessibility */
.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  padding:10px 12px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:var(--shadow);
  z-index:9999;
}

.container{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--pad);
}

/* Header + Nav (single nav per page) */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--white) 92%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width: 220px;
}
.brand a{
  display:inline-flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:inherit;
}
.brand img{
  width: 190px;
  height: auto;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:14px;
}

.nav-toggle{
  display:none;
  border:1px solid var(--border);
  background: var(--white);
  border-radius: 12px;
  padding: 10px 12px;
  line-height:1;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}
.nav-toggle:focus{outline:none; box-shadow: var(--focus)}

.nav-links{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap: 8px;
}

.nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 12px;
  border-radius: 999px;
  text-decoration:none;
  color: color-mix(in srgb, var(--purple) 85%, black);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .2px;
}
.nav a:hover{
  background: color-mix(in srgb, var(--teal) 16%, white);
}
.nav a[aria-current="page"]{
  background: color-mix(in srgb, var(--purple) 12%, white);
  border: 1px solid color-mix(in srgb, var(--purple) 20%, white);
}

/* Mobile nav: toggle same links; no duplicate nav */
@media (max-width: 980px){
  .brand img{width: 170px}
  .nav{gap:10px}
  .nav-toggle{display:inline-flex}
  .nav-links{
    display:none;
    position:absolute;
    left: var(--pad);
    right: var(--pad);
    top: calc(100% + 10px);
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 12px;
    box-shadow: var(--shadow);
  }
  .nav-links a{justify-content:flex-start; width:100%; border-radius: 12px}
  .nav.is-open .nav-links{display:flex; flex-direction:column; align-items:stretch}
}

/* Typography (headings in Century Gothic per brand) */
h1,h2,h3{
  font-family: "Century Gothic", "CenturyGothic", "AppleGothic", "Futura", "Trebuchet MS", Arial, sans-serif;
  line-height:1.2;
  margin: 0 0 12px 0;
  color: color-mix(in srgb, var(--navy) 75%, black);
}

h1{font-size: clamp(30px, 4vw, 44px); letter-spacing: -0.6px}
h2{font-size: clamp(22px, 2.6vw, 30px)}
h3{font-size: 18px}

p{margin: 0 0 14px 0; color: color-mix(in srgb, var(--ink) 88%, var(--navy))}
.small{font-size: 14px; color: color-mix(in srgb, var(--ink) 70%, white)}

/* Buttons / CTAs */
.actions{display:flex; flex-wrap:wrap; gap:10px; margin-top: 14px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid transparent;
  text-decoration:none;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .2px;
}
.btn:focus{outline:none; box-shadow: var(--focus)}
.btn-primary{
  background: color-mix(in srgb, var(--purple) 88%, black);
  color: var(--white);
}
.btn-primary:hover{background: color-mix(in srgb, var(--purple) 76%, black)}
.btn-secondary{
  background: color-mix(in srgb, var(--green) 70%, white);
  color: color-mix(in srgb, var(--navy) 70%, black);
  border-color: color-mix(in srgb, var(--green) 35%, white);
}
.btn-secondary:hover{background: color-mix(in srgb, var(--green) 62%, white)}
.btn-ghost{
  background: var(--white);
  color: color-mix(in srgb, var(--navy) 78%, black);
  border-color: var(--border);
}
.btn-ghost:hover{background: color-mix(in srgb, var(--blue) 10%, white)}

/* Hero */
.hero{
  padding: 34px 0 18px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items: stretch;
}
@media (max-width: 900px){
  .hero-grid{grid-template-columns: 1fr}
}

.hero-card{
  background: linear-gradient(180deg, color-mix(in srgb, var(--teal) 14%, white), var(--white));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
}

.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-weight: 800;
  letter-spacing: .18px;
  color: color-mix(in srgb, var(--purple) 78%, black);
  background: color-mix(in srgb, var(--purple) 10%, white);
  border: 1px solid color-mix(in srgb, var(--purple) 18%, white);
  padding: 8px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
}

.tagline{
  font-size: 18px;
  color: color-mix(in srgb, var(--ink) 78%, var(--navy));
  margin-bottom: 0;
}

.hero-aside{
  background: linear-gradient(180deg, color-mix(in srgb, var(--green) 14%, white), var(--white));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.contact-chip{
  display:flex;
  flex-direction:column;
  gap: 6px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px;
}
.contact-chip strong{font-family: "Century Gothic", Arial, sans-serif; color: color-mix(in srgb, var(--navy) 75%, black)}
.contact-chip a{color: color-mix(in srgb, var(--navy) 78%, black)}

/* Sections */
.section{
  padding: 18px 0 6px;
}

.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}

.card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  padding: 18px;
}

.card h2{margin-top: 4px}

.col-7{grid-column: span 7}
.col-5{grid-column: span 5}
.col-4{grid-column: span 4}
.col-6{grid-column: span 6}
.col-12{grid-column: span 12}

@media (max-width: 900px){
  .col-7,.col-5,.col-4,.col-6{grid-column: span 12}
}

.quick-links{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin-top: 10px;
}
@media (max-width: 520px){
  .quick-links{grid-template-columns: 1fr}
}

.link-card{
  display:flex;
  flex-direction:column;
  gap:6px;
  text-decoration:none;
  color: inherit;
  border-radius: 16px;
  padding: 14px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--blue) 10%, white), var(--white));
}
.link-card:hover{background: linear-gradient(180deg, color-mix(in srgb, var(--blue) 14%, white), var(--white))}
.link-card strong{
  font-family: "Century Gothic", Arial, sans-serif;
  color: color-mix(in srgb, var(--navy) 78%, black);
}
.link-card span{color: color-mix(in srgb, var(--ink) 75%, var(--navy)); font-size: 14px}

.media{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.figure{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--teal) 10%, white);
}
.figure img{display:block; width:100%; height:auto}

/* Footer */
.site-footer{
  margin-top: 26px;
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--navy) 6%, white);
}
.footer-inner{
  padding: 22px 0;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items:start;
}
@media (max-width: 900px){
  .footer-inner{grid-template-columns: 1fr}
}

.footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}
.footer-nav a{
  color: color-mix(in srgb, var(--navy) 78%, black);
  text-decoration:none;
  font-weight: 650;
  font-size: 14px;
}
.footer-nav a:hover{text-decoration:underline}

.fineprint{
  margin-top: 10px;
  font-size: 13px;
  color: color-mix(in srgb, var(--ink) 70%, white);
}

/* Utility */
.divider{
  height: 1px;
  background: var(--border);
  margin: 14px 0;
}

.visually-hidden{
  position:absolute !important;
  height:1px; width:1px;
  overflow:hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space:nowrap;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
}
