/* Weissman Tutors — style.css (revamped) */

/* ===== Theme tokens ===== */
:root{
  /* Palette: navy + soft gray + green accent */
  --navy-900:#0b1730;
  --navy-800:#112244;
  --navy-700:#1a2a4a;
  --ink:#0e1320;
  --muted:#5a6578;
  --paper:#ffffff;
  --surface:#f4f6fb;
  --border:#e3e8f2;
  --accent:#17845f;
  --accent-600:#136a50;
  --focus:#ffd166;

  --radius:14px;
  --shadow:0 10px 30px rgba(11,23,48,.08);
  --pad:clamp(16px,3vw,28px);
  --maxw:1120px;

  /* Hero knobs */
  --hero-overlay: .86;     /* 0 = no wash, 1 = full white */
  --hero-min-h: 62vh;      /* visual height target */
}

/* ===== Base ===== */
html{scroll-behavior:smooth;}
*{box-sizing:border-box;}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:var(--surface);
  line-height:1.6;
  -webkit-text-size-adjust:100%;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--accent-600);text-decoration:none;}
a:hover{text-decoration:underline;}
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;border-radius:6px;}

.wrap{max-width:var(--maxw);margin-inline:auto;padding:0 var(--pad);}
.section{
  padding:clamp(56px,8vw,96px) 0;
  background:var(--paper);
  border-top:1px solid var(--border);
}
.section.alt{background:linear-gradient(0deg,var(--surface),var(--surface));}
h1,h2,h3{line-height:1.2;margin:0 0 12px;}
h2{font-size:clamp(1.5rem,2.2vw,2rem);}
p{margin:0 0 12px;color:var(--ink);}
.muted{color:var(--muted);}

/* ===== Skip link ===== */
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip:focus{
  position:fixed;left:16px;top:16px;width:auto;height:auto;background:#fff;
  padding:10px 14px;z-index:999;border-radius:10px;box-shadow:var(--shadow);
}

/* ===== Header / Nav ===== */
header{
  position:sticky;top:0;z-index:100;
  background:var(--paper);
  border-bottom:1px solid var(--border);
  box-shadow:0 6px 20px rgba(10,20,40,.04);
}
.nav{
  display:flex;align-items:center;gap:16px;
  padding:12px var(--pad);
  max-width:var(--maxw);margin:auto;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.logo{
  width:42px;
  height:42px;
  flex:0 0 auto;
  border-radius:8px;
  object-fit:contain;
  display:block;
}

.wordmark{font-weight:700;letter-spacing:.2px;color:var(--navy-900);}
nav{margin-left:auto;display:flex;flex-wrap:wrap;gap:10px 14px;}
nav a{
  padding:8px 10px;border-radius:999px;color:var(--navy-700);border:1px solid transparent;
}
nav a:hover{background:rgba(23,132,95,.08);text-decoration:none;}

/* ===== Hero (now uses hero.jpg) ===== */
.hero{
  position:relative;
  min-height:var(--hero-min-h);
  display:grid;place-items:center;
  text-align:left;
  padding:clamp(64px,10vw,120px) 0;
  border-bottom:1px solid var(--border);

  /* Background image + soft readable overlay */
  background-image:
    linear-gradient(180deg, rgba(255,255,255,var(--hero-overlay)), rgba(247,249,252,calc(var(--hero-overlay)*0.92))),
    url("hero.jpg");
  background-size:cover, cover;
  background-position:center, center;
  background-repeat:no-repeat, no-repeat;
}
.hero .wrap{width:100%;}
.hero h1{font-size:clamp(1.9rem,3.8vw,2.7rem);color:var(--navy-900);max-width:28ch;}
.hero p.lead{font-size:clamp(1rem,2vw,1.15rem);color:var(--navy-700);max-width:60ch;margin-top:6px;}
.chip{
  display:inline-block;padding:6px 10px;background:rgba(17,34,68,.08);
  color:var(--navy-700);border-radius:999px;font-size:.95rem;margin-bottom:8px;
}
.cta{
  display:inline-block;margin-top:18px;padding:12px 18px;border-radius:999px;font-weight:600;
  background:var(--accent);color:#fff;border:1px solid var(--accent-600);
  box-shadow:0 10px 20px rgba(23,132,95,.18);text-decoration:none;
}
.cta:hover{filter:brightness(.96);text-decoration:none;}
.cta:active{transform:translateY(1px);}

/* ===== Layout patterns ===== */
.grid{display:grid;gap:18px;}
@media (min-width:820px){
  .grid.cols-2{grid-template-columns:1fr 1fr;}
  .grid.cols-3{grid-template-columns:repeat(3,1fr);}
}
ul.clean{margin:0;padding-left:1.1em;}
ul.clean li{margin:.4em 0;}
.card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);
}
.steps{counter-reset:step;}
.steps li{list-style:none;margin:0 0 10px;padding-left:48px;position:relative;}
.steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:0;top:0;width:34px;height:34px;border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent-600));
  color:#fff;display:grid;place-items:center;font-weight:700;box-shadow:var(--shadow);
}

/* ===== Pricing ===== */
.price{font-size:clamp(1.6rem,3vw,2rem);color:var(--navy-900);font-weight:800;}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;background:rgba(23,132,95,.1);color:var(--accent-600);font-weight:600;}

/* ===== Testimonials ===== */
blockquote{
  margin:0;font-style:italic;color:var(--navy-700);
  border-left:4px solid var(--accent);padding-left:14px;
}

/* ===== Contact ===== */
.contactbox{
  border:2px solid var(--accent);border-radius:var(--radius);
  padding:18px;background:#fbfefd;
}
.btn-secondary{
  display:inline-block;padding:12px 18px;border-radius:999px;font-weight:600;
  background:var(--navy-800);color:#fff;border:1px solid var(--navy-900);text-decoration:none;
}
.btn-secondary:hover{filter:brightness(1.05);text-decoration:none;}

/* ===== Footer ===== */
footer{padding:28px 0;background:var(--navy-900);color:#dfe5f2;margin-top:24px;}
footer a{color:#dfe5f2;opacity:.9;}
footer a:hover{opacity:1;text-decoration:underline;}
.footnav{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;}

/* ===== Utilities ===== */
.visually-hidden{
  position:absolute !important;height:1px;width:1px;overflow:hidden;
  clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px;
}

/* Anchors spacing for sticky header */
:target{scroll-margin-top:84px;}

/* Motion preferences */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
}
