/* ===== from passthewritten-homepage-mockup.html ===== */
:root{
    --paper:#F1EFE2;
    --paper-deep:#E7E3D0;
    --ink:#1B2A40;
    --ink-soft:#46566D;
    --magenta:#A8324A;
    --amber:#CE8A2E;
    --olive:#6E7F58;
    --white:#FFFFFF;
    --line:#C9C4AC;
    --radius:2px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--paper);
    color:var(--ink);
    font-family:'Inter',sans-serif;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,.display{
    font-family:'Space Grotesk',sans-serif;
    color:var(--ink);
    margin:0;
    letter-spacing:-0.01em;
  }
  .mono{
    font-family:'IBM Plex Mono',monospace;
    letter-spacing:0.02em;
  }
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  /* ---------- NAV ---------- */
  .nav{
    position:sticky;top:0;z-index:50;
    background:rgba(241,239,226,0.92);
    backdrop-filter:blur(6px);
    border-bottom:1px solid var(--line);
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover{color:var(--ink);}
  .nav-cta{
    background:var(--ink);color:var(--paper);
    padding:10px 18px;border-radius:var(--radius);
    font-size:13.5px;font-weight:600;
    font-family:'IBM Plex Mono',monospace;
  }
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-login{
    border:1.5px solid var(--ink);color:var(--ink);
    padding:9px 16px;border-radius:var(--radius);
    font-size:13.5px;font-weight:600;
    font-family:'IBM Plex Mono',monospace;
    transition:background .15s ease;
  }
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  /* ---------- HERO ---------- */
  .hero{
    position:relative;
    overflow:hidden;
    padding:88px 0 64px;
    background:
      repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
      repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
  }
  .hero-grid{
    display:grid;
    grid-template-columns:1.1fr 0.9fr;
    gap:40px;
    align-items:center;
  }
  @media(max-width:880px){.hero-grid{grid-template-columns:1fr;}}
  .eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    font-family:'IBM Plex Mono',monospace;
    font-size:12.5px;font-weight:500;
    color:var(--magenta);
    letter-spacing:0.08em;text-transform:uppercase;
    margin-bottom:18px;
  }
  .eyebrow::before{
    content:"";width:7px;height:7px;background:var(--magenta);
    clip-path:polygon(50% 0%, 0% 100%, 100% 100%);
  }
  .hero h1{
    font-size:clamp(36px,5.4vw,60px);
    line-height:1.02;
    font-weight:700;
    max-width:13ch;
  }
  .hero h1 em{
    font-style:normal;color:var(--magenta);
  }
  .hero p.sub{
    margin-top:22px;
    font-size:18px;line-height:1.55;
    color:var(--ink-soft);
    max-width:46ch;
  }
  .hero-ctas{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}
  .btn-primary{
    background:var(--ink);color:var(--paper);
    padding:15px 26px;border-radius:var(--radius);
    font-weight:600;font-size:15px;
    display:inline-flex;align-items:center;gap:8px;
    transition:background .15s ease, transform .15s ease;
  }
  .btn-primary:hover{background:#0F1A2B;transform:translateY(-1px);}
  .btn-secondary{
    border:1.5px solid var(--ink);color:var(--ink);
    padding:14px 24px;border-radius:var(--radius);
    font-weight:600;font-size:15px;
    display:inline-flex;align-items:center;gap:8px;
    transition:background .15s ease;
  }
  .btn-secondary:hover{background:rgba(27,42,64,0.06);}

  .hero-trust{
    margin-top:36px;
    display:flex;gap:22px;flex-wrap:wrap;
    font-family:'IBM Plex Mono',monospace;
    font-size:12.5px;color:var(--ink-soft);
  }
  .hero-trust span{display:flex;align-items:center;gap:7px;}
  .dot{width:5px;height:5px;border-radius:50%;background:var(--olive);flex:none;}

  /* compass rose */
  .rose-wrap{position:relative;display:flex;align-items:center;justify-content:center;}
  .rose-wrap svg{width:100%;max-width:380px;height:auto;}
  @media(max-width:880px){.rose-wrap{display:none;}}

  /* ---------- CHART STRIP ---------- */
  .chart-strip{padding:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
  .chart-svg{width:100%;height:auto;display:block;}

  /* ---------- SCREENSHOT SLIDER ---------- */
  .slider-row{
    display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
    padding-bottom:8px;margin:0 -4px;
    scrollbar-width:thin;
  }
  .slide{
    flex:0 0 auto;width:300px;scroll-snap-align:start;
  }
  .device-frame{
    background:var(--ink);border-radius:10px;padding:10px 10px 14px;
  }
  .device-frame .screen{
    background:var(--white);border-radius:4px;overflow:hidden;
    aspect-ratio:16/10.4;
  }
  .device-frame .screen img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;}
  .device-dot{width:6px;height:6px;border-radius:50%;background:var(--paper);opacity:0.4;margin:0 auto 8px;}
  .slide-caption{
    margin-top:14px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);
  }
  .slide-caption strong{color:var(--ink);font-weight:600;}
  .slider-controls{display:flex;justify-content:flex-end;gap:10px;margin-bottom:20px;}
  .slider-btn{
    width:38px;height:38px;border-radius:50%;border:1.5px solid var(--ink);
    display:flex;align-items:center;justify-content:center;cursor:pointer;background:none;
    transition:background .15s ease;
  }
  .slider-btn:hover{background:rgba(27,42,64,0.06);}
  .statline{
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    background:var(--paper-deep);
  }
  .statline-inner{
    display:grid;grid-template-columns:repeat(4,1fr);
    position:relative;
  }
  @media(max-width:760px){.statline-inner{grid-template-columns:repeat(2,1fr);}}
  .stat{
    padding:30px 24px;text-align:left;
    border-left:1px solid var(--line);
  }
  .stat:first-child{border-left:none;}
  @media(max-width:760px){.stat:nth-child(odd){border-left:none;}.stat{border-left:1px solid var(--line);}}
  .stat .num{
    font-family:'Space Grotesk',sans-serif;
    font-size:30px;font-weight:700;color:var(--magenta);
    display:block;
  }
  .stat .lbl{
    font-family:'IBM Plex Mono',monospace;
    font-size:12px;color:var(--ink-soft);
    text-transform:uppercase;letter-spacing:0.06em;
    margin-top:4px;display:block;
  }

  /* ---------- SECTION GENERIC ---------- */
  section{padding:96px 0;}
  .section-head{max-width:640px;margin-bottom:56px;}
  .section-eyebrow{
    font-family:'IBM Plex Mono',monospace;font-size:12.5px;
    color:var(--magenta);text-transform:uppercase;letter-spacing:0.08em;
    margin-bottom:14px;display:block;
  }
  .section-head h2{font-size:clamp(28px,3.4vw,40px);font-weight:700;line-height:1.1;}
  .section-head p{margin-top:16px;color:var(--ink-soft);font-size:16.5px;line-height:1.6;}

  /* ---------- HOW IT WORKS ---------- */
  .flow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);}
  @media(max-width:760px){.flow{grid-template-columns:1fr;}}
  .flow-step{padding:34px 30px;border-left:1px solid var(--line);position:relative;}
  .flow-step:first-child{border-left:none;}
  @media(max-width:760px){.flow-step{border-left:none;border-top:1px solid var(--line);}.flow-step:first-child{border-top:none;}}
  .flow-code{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--olive);font-weight:600;}
  .flow-step h3{font-size:20px;margin-top:10px;font-weight:600;}
  .flow-step p{margin-top:10px;color:var(--ink-soft);font-size:14.5px;line-height:1.55;}

  /* ---------- FEATURES ---------- */
  .feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:880px){.feat-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.feat-grid{grid-template-columns:1fr;}}
  .feat{background:var(--white);padding:30px 26px;}
  .feat-icon{width:30px;height:30px;margin-bottom:18px;}
  .feat-wpt{
    font-family:'IBM Plex Mono',monospace;font-size:11.5px;
    color:var(--ink-soft);display:flex;align-items:center;gap:7px;margin-bottom:14px;
  }
  .feat-wpt svg{width:10px;height:10px;flex:none;}
  .feat h3{font-size:17.5px;font-weight:600;}
  .feat p{margin-top:9px;font-size:14px;color:var(--ink-soft);line-height:1.55;}

  /* ---------- COURSE FINDER TEASER ---------- */
  .finder{
    background:var(--ink);color:var(--paper);
    border-radius:4px;
    padding:52px 48px;
    display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;
  }
  @media(max-width:880px){.finder{grid-template-columns:1fr;padding:40px 28px;}}
  .finder h2{color:var(--paper);font-size:clamp(24px,3vw,32px);}
  .finder p{color:#B8C2D4;margin-top:14px;font-size:15.5px;line-height:1.6;}
  .finder-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
  .chip{
    font-family:'IBM Plex Mono',monospace;font-size:12.5px;
    border:1px solid rgba(241,239,226,0.3);color:#D8DEE8;
    padding:8px 14px;border-radius:20px;
  }
  .finder-right{
    background:rgba(241,239,226,0.06);
    border:1px solid rgba(241,239,226,0.18);
    border-radius:var(--radius);
    padding:28px;
  }
  .finder-price-row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid rgba(241,239,226,0.14);}
  .finder-price-row:last-of-type{border-bottom:none;}
  .finder-price-row .name{font-size:14.5px;font-weight:500;}
  .finder-price-row .price{font-family:'IBM Plex Mono',monospace;color:var(--amber);font-weight:600;}
  .finder-cta{
    margin-top:22px;display:inline-flex;align-items:center;gap:8px;
    background:var(--paper);color:var(--ink);
    padding:13px 22px;border-radius:var(--radius);font-weight:600;font-size:14.5px;width:100%;justify-content:center;
  }

  /* ---------- COMPARISON ---------- */
  .table-wrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);overflow-x:auto;}
  table{width:100%;border-collapse:collapse;min-width:680px;}
  th,td{padding:16px 18px;text-align:left;font-size:14px;border-bottom:1px solid var(--line);}
  thead th{
    font-family:'IBM Plex Mono',monospace;font-size:11.5px;
    text-transform:uppercase;letter-spacing:0.05em;color:var(--ink-soft);
    background:var(--paper-deep);font-weight:600;
  }
  tbody tr:last-child td{border-bottom:none;}
  td.us{font-weight:600;color:var(--olive);}
  td.us::before{content:"✓ ";}
  th:first-child,td:first-child{font-weight:600;}

  /* ---------- FAQ ---------- */
  .faq-item{border-bottom:1px solid var(--line);}
  .faq-q{
    width:100%;text-align:left;background:none;border:none;cursor:pointer;
    padding:22px 0;display:flex;justify-content:space-between;align-items:center;
    font-family:'Space Grotesk',sans-serif;font-size:16.5px;font-weight:600;color:var(--ink);
  }
  .faq-q .plus{font-family:'IBM Plex Mono',monospace;font-weight:400;color:var(--magenta);font-size:18px;transition:transform .2s ease;}
  .faq-item.open .plus{transform:rotate(45deg);}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;}
  .faq-a p{padding:0 0 22px;color:var(--ink-soft);font-size:14.5px;line-height:1.6;max-width:62ch;}

  /* ---------- FOOTER CTA ---------- */
  .footer-cta{
    text-align:center;padding:90px 0 70px;
  }
  .footer-cta h2{font-size:clamp(28px,4vw,42px);max-width:16ch;margin:0 auto;}
  .footer-cta p{margin-top:14px;color:var(--ink-soft);font-size:16px;}
  .footer-cta .hero-ctas{justify-content:center;}

  footer{
    border-top:1px solid var(--line);
    padding:40px 0;
    font-size:13px;color:var(--ink-soft);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  }

/* ===== from passthewritten-courses-mockup.html ===== */
:root{
    --paper:#F1EFE2;
    --paper-deep:#E7E3D0;
    --ink:#1B2A40;
    --ink-soft:#46566D;
    --magenta:#A8324A;
    --amber:#CE8A2E;
    --olive:#6E7F58;
    --white:#FFFFFF;
    --line:#C9C4AC;
    --radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  /* NAV (shared) */
  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover,.nav-links a.active{color:var(--ink);}
  .nav-links a.active{color:var(--magenta);}
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  /* PAGE HEADER */
  .pageheader{
    padding:60px 0 40px;
    background:repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
               repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
    border-bottom:1px solid var(--line);
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .crumb a:hover{color:var(--ink);}
  .pageheader h1{font-size:clamp(32px,4.6vw,48px);font-weight:700;max-width:16ch;}
  .pageheader p{margin-top:14px;color:var(--ink-soft);font-size:16.5px;max-width:60ch;line-height:1.6;}
  .header-notes{display:flex;gap:22px;flex-wrap:wrap;margin-top:24px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--ink-soft);}
  .header-notes span{display:flex;align-items:center;gap:7px;}
  .dot{width:5px;height:5px;border-radius:50%;background:var(--olive);flex:none;}
  .amex-notice{
    margin-top:14px;display:inline-flex;align-items:center;gap:8px;
    font-size:13px;color:var(--magenta);
    background:rgba(168,50,74,0.07);border:1px solid rgba(168,50,74,0.25);
    padding:8px 14px;border-radius:20px;
  }
  .amex-notice svg{flex:none;width:15px;height:15px;}

  /* BUNDLE BANNER */
  .banner{
    margin:36px 0 0;
    background:var(--ink);color:var(--paper);
    border-radius:4px;padding:20px 26px;
    display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
  }
  .banner p{margin:0;font-size:14.5px;color:#D8DEE8;}
  .banner strong{color:var(--paper);}
  .banner .code{font-family:'IBM Plex Mono',monospace;background:rgba(241,239,226,0.12);padding:3px 8px;border-radius:3px;font-size:13px;}

  /* FILTER BAR */
  .filter-bar{
    position:sticky;top:68px;z-index:40;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:18px 0;
  }
  .filter-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
  .filter-label{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.06em;margin-right:6px;}
  .chip-btn{
    font-family:'IBM Plex Mono',monospace;font-size:12.5px;
    border:1px solid var(--line);background:var(--white);color:var(--ink-soft);
    padding:8px 14px;border-radius:20px;cursor:pointer;transition:all .15s ease;
  }
  .chip-btn:hover{border-color:var(--ink);color:var(--ink);}
  .chip-btn.active{background:var(--ink);border-color:var(--ink);color:var(--paper);}
  .search-input{
    margin-left:auto;font-family:'Inter',sans-serif;font-size:14px;
    border:1px solid var(--line);background:var(--white);
    padding:9px 14px;border-radius:20px;min-width:200px;color:var(--ink);
  }
  .search-input:focus{outline:none;border-color:var(--ink);}
  @media(max-width:640px){.search-input{margin-left:0;width:100%;}}

  /* COURSE GRID */
  .courses-section{padding:48px 0 90px;}
  .group-heading{
    display:flex;align-items:baseline;gap:12px;
    margin:48px 0 20px;
  }
  .group-heading:first-child{margin-top:0;}
  .group-heading h2{font-size:21px;font-weight:600;}
  .group-heading .count{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);}
  .group-note{font-size:13.5px;color:var(--ink-soft);line-height:1.6;margin:-8px 0 20px;max-width:70ch;}
  .notice-callout{
    display:flex;gap:12px;align-items:flex-start;
    background:rgba(206,138,46,0.08);border:1px solid rgba(206,138,46,0.28);
    border-radius:var(--radius);padding:16px 18px;margin:-8px 0 24px;max-width:80ch;
  }
  .notice-callout svg{flex:none;width:17px;height:17px;margin-top:2px;}
  .notice-callout p{margin:0;font-size:13.5px;color:var(--ink-soft);line-height:1.6;}
  .notice-callout strong{color:var(--ink);}

  .course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
  @media(max-width:920px){.course-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:600px){.course-grid{grid-template-columns:1fr;}}

  .course-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    padding:22px;display:flex;flex-direction:column;
  }
  .card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
  .card-code{
    font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;
    color:var(--olive);background:#EEF1E8;padding:4px 8px;border-radius:3px;letter-spacing:0.04em;
  }
  .card-price{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:600;color:var(--magenta);white-space:nowrap;}
  .card-title{font-size:17px;font-weight:600;margin-top:14px;line-height:1.3;}
  .card-sub{font-size:13px;color:var(--ink-soft);margin-top:4px;}
  .card-blurb{font-size:13.5px;color:var(--ink-soft);line-height:1.55;margin-top:10px;flex-grow:1;}

  details.card-details{margin-top:14px;border-top:1px solid var(--line);padding-top:12px;}
  details.card-details summary{
    cursor:pointer;font-family:'IBM Plex Mono',monospace;font-size:11.5px;
    color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.05em;
    list-style:none;display:flex;align-items:center;gap:6px;
  }
  details.card-details summary::-webkit-details-marker{display:none;}
  details.card-details summary::before{content:"+";font-family:'IBM Plex Mono',monospace;color:var(--magenta);font-size:14px;}
  details.card-details[open] summary::before{content:"–";}
  details.card-details ul{margin:10px 0 0;padding-left:18px;font-size:13px;color:var(--ink-soft);line-height:1.7;}

  .card-cta{
    margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px;
    background:var(--ink);color:var(--paper);
    padding:12px 18px;border-radius:var(--radius);font-weight:600;font-size:14px;
    transition:background .15s ease;
  }
  .card-cta:hover{background:#0F1A2B;}

  /* FINE PRINT */
  .fineprint{
    margin-top:80px;padding-top:36px;border-top:1px solid var(--line);
    font-size:12.5px;color:var(--ink-soft);line-height:1.7;max-width:80ch;
  }
  .fineprint h3{font-size:14px;margin-bottom:10px;}

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;}
  .wrap.footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a:hover{color:var(--ink);}

  .empty-state{display:none;text-align:center;padding:60px 20px;color:var(--ink-soft);font-size:14.5px;}
  .empty-state.show{display:block;}

/* ===== from passthewritten-features-mockup.html ===== */
:root{
    --paper:#F1EFE2;
    --paper-deep:#E7E3D0;
    --ink:#1B2A40;
    --ink-soft:#46566D;
    --magenta:#A8324A;
    --amber:#CE8A2E;
    --olive:#6E7F58;
    --white:#FFFFFF;
    --line:#C9C4AC;
    --radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  /* NAV */
  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover,.nav-links a.active{color:var(--ink);}
  .nav-links a.active{color:var(--magenta);}
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  /* PAGE HEADER */
  .pageheader{
    padding:60px 0 48px;
    background:repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
               repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
    border-bottom:1px solid var(--line);
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .crumb a:hover{color:var(--ink);}
  .pageheader h1{font-size:clamp(32px,4.6vw,48px);font-weight:700;max-width:18ch;}
  .pageheader p{margin-top:14px;color:var(--ink-soft);font-size:16.5px;max-width:62ch;line-height:1.6;}

  /* SECTION GENERIC */
  section{padding:88px 0;}
  .section-head{max-width:640px;margin-bottom:48px;}
  .section-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--magenta);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;display:block;}
  .section-head h2{font-size:clamp(26px,3.2vw,36px);font-weight:700;line-height:1.1;}
  .section-head p{margin-top:14px;color:var(--ink-soft);font-size:16px;line-height:1.6;}

  /* FEATURE GRID (reused icon style) */
  .feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:880px){.feat-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.feat-grid{grid-template-columns:1fr;}}
  .feat{background:var(--white);padding:30px 26px;}
  .feat-icon{width:30px;height:30px;margin-bottom:18px;}
  .feat-wpt{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-soft);display:flex;align-items:center;gap:7px;margin-bottom:14px;}
  .feat-wpt svg{width:10px;height:10px;flex:none;}
  .feat h3{font-size:17.5px;font-weight:600;}
  .feat p{margin-top:9px;font-size:14px;color:var(--ink-soft);line-height:1.55;}

  /* SCREENSHOT SLIDER (reused) */
  .slider-row{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;margin:0 -4px;scrollbar-width:thin;}
  .slide{flex:0 0 auto;width:300px;scroll-snap-align:start;}
  .device-frame{background:var(--ink);border-radius:10px;padding:10px 10px 14px;}
  .device-frame .screen{background:var(--white);border-radius:4px;overflow:hidden;aspect-ratio:16/10.4;}
  .device-frame .screen img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;}
  .device-dot{width:6px;height:6px;border-radius:50%;background:var(--paper);opacity:0.4;margin:0 auto 8px;}
  .slide-caption{margin-top:14px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);}
  .slide-caption strong{color:var(--ink);font-weight:600;}
  .slider-controls{display:flex;justify-content:flex-end;gap:10px;}
  .slider-btn{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;background:none;transition:background .15s ease;}
  .slider-btn:hover{background:rgba(27,42,64,0.06);}

  /* OTHER FEATURES CHECKLIST */
  .checklist{
    display:grid;grid-template-columns:repeat(2,1fr);gap:0;
    border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);
  }
  @media(max-width:760px){.checklist{grid-template-columns:1fr;}}
  .check-item{
    display:flex;gap:12px;align-items:flex-start;padding:18px 22px;
    border-bottom:1px solid var(--line);border-right:1px solid var(--line);
  }
  .check-item:nth-child(2n){border-right:none;}
  @media(max-width:760px){.check-item{border-right:none;}}
  .check-item svg{flex:none;width:16px;height:16px;margin-top:2px;}
  .check-item p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.5;}
  .check-item .footnote{display:block;font-size:12px;color:var(--ink-soft);opacity:0.75;margin-top:4px;}

  /* SYSTEM REQUIREMENTS */
  .reqs{
    background:var(--ink);color:var(--paper);border-radius:4px;padding:48px;
    display:grid;grid-template-columns:1fr 1fr;gap:44px;
  }
  @media(max-width:880px){.reqs{grid-template-columns:1fr;padding:36px 26px;}}
  .reqs h2{color:var(--paper);font-size:clamp(24px,3vw,30px);}
  .reqs p{color:#B8C2D4;margin-top:14px;font-size:15px;line-height:1.65;}
  .platform-row{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;}
  .platform-chip{
    display:flex;align-items:center;gap:8px;
    font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:#D8DEE8;
    border:1px solid rgba(241,239,226,0.25);padding:8px 14px;border-radius:20px;
  }
  .platform-chip svg{width:14px;height:14px;flex:none;}
  .reqs-note{
    background:rgba(241,239,226,0.06);border:1px solid rgba(241,239,226,0.18);
    border-radius:var(--radius);padding:24px;font-size:14px;color:#D8DEE8;line-height:1.65;
  }
  .reqs-note strong{color:var(--paper);}

  /* FOOTER CTA */
  .footer-cta{text-align:center;padding:90px 0 70px;}
  .footer-cta h2{font-size:clamp(26px,4vw,38px);max-width:18ch;margin:0 auto;}
  .footer-cta p{margin-top:14px;color:var(--ink-soft);font-size:16px;}
  .btn-primary{
    margin-top:26px;background:var(--ink);color:var(--paper);padding:15px 26px;border-radius:var(--radius);
    font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;
    transition:background .15s ease, transform .15s ease;
  }
  .btn-primary:hover{background:#0F1A2B;transform:translateY(-1px);}

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);}
  .footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a:hover{color:var(--ink);}

/* ===== from passthewritten-schools-mockup.html ===== */
:root{
    --paper:#F1EFE2;
    --paper-deep:#E7E3D0;
    --ink:#1B2A40;
    --ink-soft:#46566D;
    --magenta:#A8324A;
    --amber:#CE8A2E;
    --olive:#6E7F58;
    --white:#FFFFFF;
    --line:#C9C4AC;
    --radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  /* NAV */
  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover,.nav-links a.active{color:var(--ink);}
  .nav-links a.active{color:var(--magenta);}
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  /* HERO */
  .hero{
    padding:72px 0 56px;
    background:repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
               repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
    border-bottom:1px solid var(--line);
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:center;}
  @media(max-width:880px){.hero-grid{grid-template-columns:1fr;}}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;font-weight:500;color:var(--magenta);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:18px;}
  .eyebrow::before{content:"";width:7px;height:7px;background:var(--magenta);clip-path:polygon(50% 0%, 0% 100%, 100% 100%);}
  .hero h1{font-size:clamp(32px,4.6vw,50px);line-height:1.08;font-weight:700;max-width:15ch;}
  .hero p.sub{margin-top:18px;font-size:17px;line-height:1.6;color:var(--ink-soft);max-width:48ch;}
  .hero-stat-row{display:flex;gap:28px;margin-top:30px;flex-wrap:wrap;}
  .hero-stat .num{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;color:var(--magenta);display:block;}
  .hero-stat .lbl{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.05em;margin-top:2px;display:block;}
  .btn-primary{
    margin-top:30px;background:var(--ink);color:var(--paper);padding:15px 26px;border-radius:var(--radius);
    font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;
    transition:background .15s ease, transform .15s ease;
  }
  .btn-primary:hover{background:#0F1A2B;transform:translateY(-1px);}

  .hero-visual{background:var(--white);border:1px solid var(--line);border-radius:6px;padding:10px;}
  .hero-visual img{width:100%;border-radius:3px;display:block;}
  .hero-visual-cap{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-soft);padding:10px 6px 2px;}

  /* SECTION GENERIC */
  section{padding:88px 0;}
  .section-head{max-width:640px;margin-bottom:44px;}
  .section-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--magenta);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;display:block;}
  .section-head h2{font-size:clamp(26px,3.2vw,36px);font-weight:700;line-height:1.1;}
  .section-head p{margin-top:14px;color:var(--ink-soft);font-size:16px;line-height:1.6;}

  /* BENEFITS */
  .benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:920px){.benefit-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.benefit-grid{grid-template-columns:1fr;}}
  .benefit{background:var(--white);padding:28px 24px;}
  .benefit-icon{width:28px;height:28px;margin-bottom:16px;}
  .benefit h3{font-size:16px;font-weight:600;}
  .benefit p{margin-top:8px;font-size:13.5px;color:var(--ink-soft);line-height:1.55;}

  /* PRICING / ELIGIBILITY PANEL */
  .panel-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:820px){.panel-row{grid-template-columns:1fr;}}
  .panel{background:var(--white);padding:36px;}
  .panel .tag{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--olive);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:12px;display:block;}
  .panel h3{font-size:19px;font-weight:600;}
  .panel p{margin-top:10px;font-size:14.5px;color:var(--ink-soft);line-height:1.65;}
  .panel ul{margin:14px 0 0;padding-left:18px;font-size:14px;color:var(--ink-soft);line-height:1.7;}

  /* FORM */
  .form-shell{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:40px;max-width:760px;}
  @media(max-width:640px){.form-shell{padding:26px;}}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
  @media(max-width:640px){.form-grid{grid-template-columns:1fr;}}
  .field{display:flex;flex-direction:column;gap:6px;}
  .field.full{grid-column:1/-1;}
  .field label{font-size:13px;font-weight:600;color:var(--ink);}
  .field label .req{color:var(--magenta);}
  .field input[type=text],
  .field input[type=email],
  .field input[type=tel],
  .field input[type=url],
  .field select,
  .field textarea{
    font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink);
    border:1px solid var(--line);background:var(--paper);
    padding:11px 13px;border-radius:var(--radius);
  }
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);background:var(--white);}
  .field .hint{font-size:12px;color:var(--ink-soft);}
  .checkbox-group{display:flex;flex-direction:column;gap:10px;margin-top:4px;}
  .checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-soft);}
  .checkbox-row input{margin-top:3px;}
  .form-submit{
    margin-top:24px;background:var(--ink);color:var(--paper);border:none;
    padding:14px 28px;border-radius:var(--radius);font-weight:600;font-size:15px;
    font-family:'Inter',sans-serif;cursor:pointer;width:100%;
  }
  .form-note{
    margin-top:18px;font-size:12.5px;color:var(--ink-soft);
    background:rgba(206,138,46,0.08);border:1px solid rgba(206,138,46,0.28);
    border-radius:var(--radius);padding:12px 14px;
  }

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);}
  .footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a:hover{color:var(--ink);}

/* ===== from passthewritten-support-mockup.html ===== */
:root{
    --paper:#F1EFE2;--paper-deep:#E7E3D0;--ink:#1B2A40;--ink-soft:#46566D;
    --magenta:#A8324A;--amber:#CE8A2E;--olive:#6E7F58;--white:#FFFFFF;--line:#C9C4AC;--radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover,.nav-links a.active{color:var(--ink);}
  .nav-links a.active{color:var(--magenta);}
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  .pageheader{
    padding:60px 0 44px;
    background:repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
               repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
    border-bottom:1px solid var(--line);
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .pageheader h1{font-size:clamp(32px,4.6vw,46px);font-weight:700;max-width:16ch;}
  .pageheader p{margin-top:14px;color:var(--ink-soft);font-size:16.5px;max-width:60ch;line-height:1.6;}

  section{padding:72px 0;}
  .section-head{max-width:640px;margin-bottom:36px;}
  .section-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--magenta);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;display:block;}
  .section-head h2{font-size:clamp(24px,3vw,32px);font-weight:700;line-height:1.1;}

  /* QUICK HELP CARDS */
  .help-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:880px){.help-grid{grid-template-columns:1fr;}}
  .help-card{background:var(--white);padding:28px 26px;}
  .help-card .icon{width:26px;height:26px;margin-bottom:14px;}
  .help-card h3{font-size:16px;font-weight:600;}
  .help-card p{margin-top:8px;font-size:13.5px;color:var(--ink-soft);line-height:1.6;}
  .help-card a{color:var(--magenta);font-weight:600;text-decoration:underline;}

  /* FORM */
  .form-shell{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:40px;max-width:680px;}
  @media(max-width:640px){.form-shell{padding:26px;}}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
  @media(max-width:560px){.form-grid{grid-template-columns:1fr;}}
  .field{display:flex;flex-direction:column;gap:6px;}
  .field.full{grid-column:1/-1;}
  .field label{font-size:13px;font-weight:600;color:var(--ink);}
  .field label .req{color:var(--magenta);}
  .field input[type=text],.field input[type=email],.field select,.field textarea{
    font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink);
    border:1px solid var(--line);background:var(--paper);padding:11px 13px;border-radius:var(--radius);
  }
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);background:var(--white);}
  .field .hint{font-size:12px;color:var(--ink-soft);}
  .captcha-box{
    margin-top:6px;border:1px dashed var(--line);border-radius:var(--radius);
    padding:16px;display:flex;align-items:center;gap:12px;background:var(--paper-deep);
  }
  .captcha-box svg{width:22px;height:22px;flex:none;color:var(--olive);}
  .captcha-box .txt{font-size:12.5px;color:var(--ink-soft);line-height:1.5;}
  .captcha-box .txt strong{color:var(--ink);}
  .form-submit{
    margin-top:24px;background:var(--ink);color:var(--paper);border:none;
    padding:14px 28px;border-radius:var(--radius);font-weight:600;font-size:15px;
    font-family:'Inter',sans-serif;cursor:pointer;width:100%;
  }
  .form-note{
    margin-top:18px;font-size:12.5px;color:var(--ink-soft);
    background:rgba(206,138,46,0.08);border:1px solid rgba(206,138,46,0.28);
    border-radius:var(--radius);padding:12px 14px;
  }

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);}
  .footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a:hover{color:var(--ink);}

/* ===== from passthewritten-study-resources-mockup.html ===== */
:root{
    --paper:#F1EFE2;--paper-deep:#E7E3D0;--ink:#1B2A40;--ink-soft:#46566D;
    --magenta:#A8324A;--amber:#CE8A2E;--olive:#6E7F58;--white:#FFFFFF;--line:#C9C4AC;--radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-links{display:flex;gap:32px;font-size:14px;font-weight:500;color:var(--ink-soft);}
  .nav-links a:hover,.nav-links a.active{color:var(--ink);}
  .nav-links a.active{color:var(--magenta);}
  .nav-cta-group{display:flex;align-items:center;gap:10px;}
  .nav-cta{background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}
  .nav-mobile-hide{display:flex;}
  @media(max-width:880px){.nav-mobile-hide{display:none;}}

  .pageheader{
    padding:60px 0 44px;
    background:repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px),
               repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(27,42,64,0.05) 39px, rgba(27,42,64,0.05) 40px);
    border-bottom:1px solid var(--line);
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .pageheader h1{font-size:clamp(32px,4.6vw,46px);font-weight:700;max-width:18ch;}
  .pageheader p{margin-top:14px;color:var(--ink-soft);font-size:16.5px;max-width:62ch;line-height:1.6;}

  section{padding:72px 0;}
  .section-head{max-width:680px;margin-bottom:36px;}
  .section-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--magenta);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;display:block;}
  .section-head h2{font-size:clamp(24px,3vw,32px);font-weight:700;line-height:1.1;}
  .section-head p{margin-top:14px;color:var(--ink-soft);font-size:15.5px;line-height:1.6;}

  /* SUPPLEMENTS TABLE-LIKE CARDS */
  .supp-list{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);}
  .supp-row{
    display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
    padding:20px 24px;border-bottom:1px solid var(--line);
  }
  .supp-row:last-child{border-bottom:none;}
  .supp-name{font-size:15.5px;font-weight:600;}
  .supp-links{display:flex;gap:10px;flex-wrap:wrap;}
  .supp-link{
    font-family:'IBM Plex Mono',monospace;font-size:12.5px;
    border:1px solid var(--line);padding:8px 14px;border-radius:20px;color:var(--ink-soft);
    transition:all .15s ease;
  }
  .supp-link:hover{border-color:var(--ink);color:var(--ink);}
  .supp-link.faa{color:var(--olive);border-color:rgba(110,127,88,0.4);}
  .supp-link.faa:hover{border-color:var(--olive);background:rgba(110,127,88,0.08);}

  /* REFERENCES GRID */
  .ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
  @media(max-width:760px){.ref-grid{grid-template-columns:1fr;}}
  .ref-card{background:var(--white);padding:24px;}
  .ref-card .code{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);}
  .ref-card h3{font-size:16px;font-weight:600;margin-top:6px;}
  .ref-card .links{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap;}

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);}
  .footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
  .footer-links{display:flex;gap:24px;}
  .footer-links a:hover{color:var(--ink);}

/* ===== from passthewritten-question-feedback-mockup.html ===== */
:root{
    --paper:#F1EFE2;--paper-deep:#E7E3D0;--ink:#1B2A40;--ink-soft:#46566D;
    --magenta:#A8324A;--amber:#CE8A2E;--olive:#6E7F58;--white:#FFFFFF;--line:#C9C4AC;--radius:2px;
  }
  *{box-sizing:border-box;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;color:var(--ink);margin:0;letter-spacing:-0.01em;}
  .mono{font-family:'IBM Plex Mono',monospace;letter-spacing:0.02em;}
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
  @media(max-width:640px){.wrap{padding:0 20px;}}

  .nav{position:sticky;top:0;z-index:50;background:rgba(241,239,226,0.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;}
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;}
  .logo-mark{width:30px;height:30px;flex:none;}
  .nav-cta-group{display:flex;align-items:center;gap:10px;margin-left:auto;}
  .nav-login{border:1.5px solid var(--ink);color:var(--ink);padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;transition:background .15s ease;}
  .nav-login:hover{background:rgba(27,42,64,0.06);}

  .pageheader{
    padding:52px 0 8px;
  }
  .crumb{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);margin-bottom:16px;}
  .pageheader h1{font-size:clamp(28px,4vw,38px);font-weight:700;max-width:20ch;}
  .pageheader p{margin-top:12px;color:var(--ink-soft);font-size:15.5px;max-width:58ch;line-height:1.6;}

  main{padding:36px 0 90px;}

  .context-banner{
    display:none;align-items:center;gap:12px;
    background:rgba(110,127,88,0.08);border:1px solid rgba(110,127,88,0.3);
    border-radius:var(--radius);padding:14px 18px;margin-bottom:28px;max-width:680px;
  }
  .context-banner.show{display:flex;}
  .context-banner svg{flex:none;width:18px;height:18px;}
  .context-banner .txt{font-size:13.5px;color:var(--ink-soft);}
  .context-banner .txt strong{color:var(--ink);font-family:'IBM Plex Mono',monospace;}

  .form-shell{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:40px;max-width:680px;}
  @media(max-width:640px){.form-shell{padding:26px;}}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
  @media(max-width:560px){.form-grid{grid-template-columns:1fr;}}
  .field{display:flex;flex-direction:column;gap:6px;}
  .field.full{grid-column:1/-1;}
  .field label{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:8px;}
  .field label .req{color:var(--magenta);}
  .auto-tag{
    font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--olive);
    background:rgba(110,127,88,0.12);padding:2px 7px;border-radius:10px;font-weight:600;
    letter-spacing:0.04em;text-transform:uppercase;
  }
  .field input[type=text],.field input[type=email],.field select,.field textarea{
    font-family:'Inter',sans-serif;font-size:14.5px;color:var(--ink);
    border:1px solid var(--line);background:var(--paper);padding:11px 13px;border-radius:var(--radius);
  }
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);background:var(--white);}
  .field input.locked{background:var(--paper-deep);color:var(--ink-soft);font-family:'IBM Plex Mono',monospace;}
  .field .hint{font-size:12px;color:var(--ink-soft);}
  .captcha-box{
    margin-top:6px;border:1px dashed var(--line);border-radius:var(--radius);
    padding:16px;display:flex;align-items:center;gap:12px;background:var(--paper-deep);
  }
  .captcha-box svg{width:22px;height:22px;flex:none;color:var(--olive);}
  .captcha-box .txt{font-size:12.5px;color:var(--ink-soft);line-height:1.5;}
  .captcha-box .txt strong{color:var(--ink);}
  .form-submit{
    margin-top:24px;background:var(--ink);color:var(--paper);border:none;
    padding:14px 28px;border-radius:var(--radius);font-weight:600;font-size:15px;
    font-family:'Inter',sans-serif;cursor:pointer;width:100%;
  }
  .form-note{
    margin-top:18px;font-size:12.5px;color:var(--ink-soft);
    background:rgba(206,138,46,0.08);border:1px solid rgba(206,138,46,0.28);
    border-radius:var(--radius);padding:12px 14px;
  }

  footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--ink-soft);}
  .footer-inner{display:flex;justify-content:space-between;width:100%;flex-wrap:wrap;gap:12px;align-items:center;}
/* ===== shared form submission status (added for live forms) ===== */
.form-status{
  margin-top:18px;font-size:13.5px;border-radius:2px;padding:12px 14px;
}
.form-status.success{
  display:flex;align-items:center;gap:12px;
  background:rgba(110,127,88,0.12);border:1.5px solid rgba(110,127,88,0.45);color:#2F3A25;
  font-size:16.5px;font-weight:600;line-height:1.5;
  padding:20px 22px;border-radius:4px;
}
.form-status.success::before{
  content:"✓";flex:none;
  width:30px;height:30px;border-radius:50%;
  background:var(--olive);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;font-weight:700;
}
.form-status.error{
  background:rgba(168,50,74,0.08);border:1px solid rgba(168,50,74,0.3);color:#7A2236;
}
.h-captcha{margin-top:4px;}

/* ===== brand logo (added) ===== */
.logo-img{
  height:34px;
  width:auto;
  display:block;
}
@media(max-width:480px){
  .logo-img{height:28px;}
}

/* ===== app store / play store links (added) ===== */
.app-links{display:flex;gap:10px;flex-wrap:wrap;}
.app-badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);background:var(--white);
  padding:9px 16px;border-radius:6px;
  font-size:13.5px;font-weight:600;color:var(--ink);
  transition:border-color .15s ease, background .15s ease;
}
.app-badge:hover{border-color:var(--ink);background:rgba(27,42,64,0.04);}
.app-badge svg{width:17px;height:17px;flex:none;}

/* ===== consolidated button base (fixes inconsistent sizing between
   .btn-primary and .btn-secondary caused by duplicate per-page rules
   above) — this block wins the cascade since it's appended last ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:50px;
  padding:0 26px;
  border-radius:var(--radius);
  font-weight:600;font-size:15px;
  line-height:1;
  border:1.5px solid transparent;
  box-sizing:border-box;
  white-space:nowrap;
  transition:background .15s ease, transform .15s ease, border-color .15s ease;
}
.btn-primary{
  background:var(--ink) !important;color:var(--paper) !important;border-color:var(--ink) !important;
  padding:0 26px !important;
}
.btn-primary:hover{background:#0F1A2B;transform:translateY(-1px);}
.btn-secondary{
  background:transparent !important;color:var(--ink) !important;border-color:var(--ink) !important;
  padding:0 26px !important;
}
/* only reset margin where two buttons sit side-by-side in a row (homepage/features
   hero) — other pages (e.g. Schools) rely on .btn-primary's own margin-top for
   spacing below the stat row, so a blanket reset there breaks that spacing */
.hero-ctas .btn-primary,.hero-ctas .btn-secondary{margin:0 !important;}
.btn-secondary:hover{background:rgba(27,42,64,0.06);}

.hero-ctas{align-items:center !important;}
.logo{
  margin-right:32px;
  flex:none;
}
@media(max-width:880px){
  .logo{margin-right:0;}
}

/* ===== real sectional chart strip (replaces illustrated version) ===== */
.chart-strip{padding:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.chart-media{
  position:relative;
  width:100%;
  max-height:340px;
  overflow:hidden;
  background:#1B2A40;
}
.chart-media img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:50% 38%;
  display:block;
}
.chart-route-svg{
  position:absolute;inset:0;
  width:100%;height:100%;
  pointer-events:none;
}
.chart-wpt{
  position:absolute;
  transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:5px;
}
.chart-wpt .dot{
  width:26px;height:26px;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,0.5));
}
.chart-wpt .lbl{
  font-family:'IBM Plex Mono',monospace;font-size:12.5px;font-weight:700;
  color:var(--paper);background:rgba(27,42,64,0.9);
  padding:4px 11px;border-radius:11px;letter-spacing:0.03em;
  white-space:nowrap;
}
.chart-caption{
  position:absolute;left:20px;bottom:16px;
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:1.5px;
  color:var(--paper);background:rgba(27,42,64,0.75);
  padding:6px 12px;border-radius:3px;text-transform:uppercase;
}
@media(max-width:640px){
  .chart-media{max-height:220px;}
  .chart-wpt .dot{width:18px;height:18px;}
  .chart-wpt .lbl{font-size:9.5px;padding:2px 7px;}
  .chart-caption{font-size:9.5px;left:12px;bottom:10px;padding:4px 9px;}
}

/* ===== lightening overlay for sectional chart (added) ===== */
.chart-overlay{
  position:absolute;inset:0;
  background:rgba(255,255,255,0.5);
}

/* ===== nav CTA fix: prevent clipping/wrapping, equalize button sizes (added) ===== */
.nav-inner{
  height:auto;
  min-height:68px;
  padding-top:10px;
  padding-bottom:10px;
  flex-wrap:nowrap;
}
.nav-cta-group{
  flex:none;
}
.nav-cta,.nav-login{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  line-height:1.2;
  box-sizing:border-box;
}

/* ===== mobile nav menu (added): Courses/Features/ACS Codes/Schools/Support
   were simply hidden below 880px with no replacement way to reach them —
   added a hamburger toggle that reveals them in a dropdown. The Log In
   button also moves into that dropdown at the same breakpoint so the logo,
   primary CTA, and toggle all have room without clipping. ===== */
.nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  padding:6px;margin-left:6px;flex:none;
  color:var(--ink);
}
.nav-toggle svg{width:22px;height:22px;display:block;}
.nav-link-login-mobile{display:none;}
@media(max-width:880px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;}
  .logo-img{max-width:150px;height:auto;}
  .nav-cta-group{gap:8px;}
  .nav-cta-group .nav-login{display:none;}
  .nav-cta{padding:9px 14px;font-size:12.5px;}
  .nav-link-login-mobile{
    display:block;
    border-top:1px solid var(--line);
    margin-top:4px;padding-top:14px !important;
    font-weight:600;
  }
  .nav-links.nav-mobile-hide{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;
    background:var(--paper);
    border-bottom:1px solid var(--line);
    padding:6px 20px 14px;
    gap:2px;
    box-shadow:0 10px 24px rgba(27,42,64,0.1);
  }
  .nav.nav-open .nav-links.nav-mobile-hide{display:flex;}
  .nav-links.nav-mobile-hide a{
    padding:12px 4px;
    border-bottom:1px solid rgba(27,42,64,0.08);
  }
  .nav-links.nav-mobile-hide a:last-child{border-bottom:none;}
}
@media(max-width:480px){
  .logo-img{max-width:130px;}
  .nav-cta-group{gap:6px;}
  .nav-cta{padding:8px 12px;font-size:11.5px;}
}
@media(max-width:360px){
  .logo-img{max-width:100px;}
  .nav-cta{padding:7px 9px;font-size:10.5px;}
}

/* ===== fix forms overflowing horizontally on mobile: grid/flex items default
   to a min-width based on their content's intrinsic size, so a <select> with
   a long option (e.g. on Support) could force the whole form wider than the
   viewport even though the track is "1fr" ===== */
.form-grid{min-width:0;}
.field{min-width:0;}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=url],
.field select,
.field textarea{
  width:100%;
  min-width:0;
  box-sizing:border-box;
}

/* ===== fix banner text contrast: a later duplicate ".pageheader p" rule
   (same specificity as ".banner p") was overriding the banner's light text
   color with --ink-soft, a muted color meant for the light page background,
   making it nearly unreadable on the dark banner ===== */
.pageheader .banner p{color:#E3E7F0 !important;}
.pageheader .banner strong{color:#FFFFFF !important;}

/* ===== screenshot lightbox (added) ===== */
.screen img{cursor:zoom-in;}
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(27,42,64,0.88);
  display:none;
  align-items:center;justify-content:center;
  padding:40px 20px;
  cursor:zoom-out;
}
.lightbox.open{display:flex;}
.lightbox img{
  max-width:min(900px,92vw);
  max-height:88vh;
  border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,0.4);
}
.lightbox-close{
  position:absolute;top:18px;right:22px;
  width:38px;height:38px;border-radius:50%;
  background:rgba(241,239,226,0.12);color:var(--paper);
  border:1px solid rgba(241,239,226,0.3);
  font-size:18px;line-height:1;cursor:pointer;
}

/* ===== testimonials section (added) ===== */
.testimonial-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-bottom:40px;
}
@media(max-width:760px){.testimonial-stats{grid-template-columns:1fr;}}
.testimonial-stat{
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:32px 28px;
}
.testimonial-stat .num{
  display:block;font-family:'Space Grotesk',sans-serif;
  font-size:42px;font-weight:700;color:var(--magenta);
  line-height:1;margin-bottom:12px;
}
.testimonial-stat .lbl{
  display:block;font-size:14.5px;color:var(--ink-soft);line-height:1.5;
}
.testimonial-quote{
  max-width:680px;margin:0 auto;
  background:var(--ink);color:var(--paper);
  border-radius:4px;padding:36px 40px;
  text-align:center;
}
@media(max-width:640px){.testimonial-quote{padding:28px 26px;}}
.testimonial-quote p{
  margin:0;font-family:'Space Grotesk',sans-serif;
  font-size:21px;line-height:1.5;font-weight:500;
}
.testimonial-quote cite{
  display:block;margin-top:18px;
  font-family:'IBM Plex Mono',monospace;font-size:12.5px;
  font-style:normal;color:#9AA7BD;letter-spacing:0.03em;
}

/* ===== AKTR sample proof image (added) ===== */
.aktr-proof{
  max-width:680px;margin:28px auto 0;
}
.aktr-proof img{
  width:100%;display:block;
  border-radius:4px;
}
