
:root {
  --blue:#003D79;
  --blue2:#0057B8;
  --green:#00843D;
  --yellow:#FFD100;
  --red:#E31B2F;
  --lightblue:#EAF5FF;
  --softblue:#F2F8FF;
  --softgreen:#EAF8EF;
  --softyellow:#FFF8D8;
  --gray:#F7FAFD;
  --dark:#12233A;
  --muted:#5F6F84;
  --border:#D6E2EF;
  --shadow:0 14px 35px rgba(0,61,121,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#fff;color:var(--dark);line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;border:3px solid var(--yellow);padding:.7rem 1rem;z-index:9999;color:#000}
.site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:99}
.header-inner{max-width:1220px;margin:auto;display:flex;align-items:center;gap:1rem;justify-content:space-between;padding:.65rem 1rem}
.logo img{width:190px;height:auto}
.nav{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.nav a{text-decoration:none;font-size:.92rem;font-weight:800;color:var(--blue);padding:.55rem .65rem;border-radius:999px}
.nav a:hover,.nav a:focus,.nav a.active{background:var(--lightblue);outline:none}
.top-tools{display:flex;align-items:center;gap:.5rem}
.lang{font-weight:800;color:var(--blue);border:1px solid var(--border);padding:.45rem .65rem;border-radius:999px;background:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:0;border-radius:.6rem;background:var(--blue);color:#fff;text-decoration:none;font-weight:900;padding:.75rem 1rem;box-shadow:0 8px 18px rgba(0,61,121,.18);cursor:pointer}
.btn:hover,.btn:focus{filter:brightness(.96);outline:3px solid rgba(255,209,0,.55)}
.btn.secondary{background:var(--green)}
.btn.gold{background:var(--yellow);color:var(--blue)}
.btn.red{background:var(--red)}
.btn.outline{background:#fff;color:var(--blue);border:2px solid var(--blue);box-shadow:none}
.mobile-menu{display:none;background:var(--blue);color:#fff;border:0;border-radius:.55rem;padding:.6rem .75rem;font-weight:900}
main{max-width:1220px;margin:auto;padding:0 1rem 1rem}
.hero{position:relative;display:grid;grid-template-columns:1.02fr .98fr;min-height:430px;background:linear-gradient(110deg,#fff 0%,#fff 48%,#f2f8ff 48%,#f7fbff 100%);border-radius:0 0 22px 22px;overflow:hidden}
.hero::after{content:"";position:absolute;right:-8%;bottom:-90px;width:62%;height:235px;background:linear-gradient(125deg,var(--green),var(--blue),var(--yellow));border-radius:70% 0 0 0;z-index:1}
.hero-copy{padding:3.3rem 1.6rem 2rem 2rem;position:relative;z-index:3}
.breadcrumb{font-size:.82rem;color:var(--muted);font-weight:700;margin-bottom:1rem}
h1{font-size:clamp(2.05rem,4vw,3.65rem);line-height:1.08;margin:.2rem 0 1rem;color:var(--blue)}
.green{color:var(--green)}
.red{color:var(--red)}
.hero p{font-size:1.12rem;max-width:540px;margin-bottom:1.2rem}
.hero-image{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:center;min-height:360px;padding-top:1rem}
.hero-image img{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:0 0 0 40px;background:#f7fbff;padding:.35rem}
.home-hero .hero-image img{object-fit:cover;object-position:center;padding:0;background:transparent}
.action-strip{position:relative;z-index:5;margin:-28px auto 1.1rem;background:#fff;border:1px solid var(--border);border-radius:26px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);gap:.2rem;padding:1rem 1.1rem}
.action-item{display:flex;gap:.8rem;align-items:flex-start;padding:.75rem;border-radius:16px}
.action-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;font-size:1.6rem;font-weight:900;flex:0 0 auto}
.action-item h3{margin:0 0 .15rem;color:var(--blue);font-size:1.02rem}
.action-item p{margin:0;color:var(--muted);font-size:.9rem}
.section{margin:1.25rem 0}
.section-header{display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:1rem}
h2{font-size:clamp(1.55rem,3vw,2.15rem);line-height:1.1;margin:.2rem 0;color:var(--blue)}
.lead{color:var(--muted);font-size:1.05rem;max-width:760px;margin:.35rem 0}
.grid{display:grid;gap:1rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 7px 22px rgba(0,61,121,.07);padding:1.1rem}
.card.center{text-align:center}
.card h3{color:var(--blue);margin:.4rem 0;font-size:1.17rem}
.card p{color:var(--muted);font-size:.96rem}
.card-img{border-radius:14px;height:185px;width:100%;object-fit:contain;object-position:center;margin:-.2rem 0 .8rem;border:1px solid var(--border);background:#f7fbff;padding:.25rem}
.big-icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin:0 auto .7rem;font-size:2rem;font-weight:900}
.page-card{min-height:230px}
.panel{background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);padding:1.4rem}
.list-links{display:grid;gap:.8rem;margin-top:1rem}
.list-links a{display:flex;justify-content:space-between;align-items:center;text-decoration:none;border:1px solid var(--border);border-radius:12px;padding:.9rem 1rem;color:var(--blue);font-weight:900;background:#fff}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.partner-grid img{width:100%;height:auto}
.news-list{display:grid;gap:.8rem}
.news-item{display:grid;grid-template-columns:74px 1fr;gap:.8rem;align-items:center}
.news-item img{width:74px;height:74px;border-radius:12px;object-fit:cover}
.form-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:22px;padding:1.5rem}
.form-row{display:grid;gap:.35rem;margin-bottom:1rem}
label{font-weight:900;color:var(--blue)}
input,select,textarea{width:100%;font-size:1rem;border:1px solid var(--border);border-radius:10px;padding:.85rem .9rem}
input:focus,select:focus,textarea:focus{outline:3px solid rgba(255,209,0,.55);border-color:var(--blue)}
.login-page{min-height:78vh;display:grid;place-items:center;background:linear-gradient(rgba(247,250,253,.55),rgba(247,250,253,.8)),url('../img/family-login.jpg');background-size:cover;background-position:center;border-radius:0 0 22px 22px;padding:2rem}
.login-box{width:min(430px,100%);background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:1.7rem}
.login-box img{width:210px;margin:0 auto 1rem}
.footer{margin-top:2rem;background:var(--blue);color:#fff;border-radius:24px 24px 0 0}
.footer-inner{max-width:1220px;margin:auto;padding:1.4rem 1rem;display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:1rem;align-items:center}
.footer img{width:205px}
.footer p{margin:.3rem 0;color:#e7f1ff}
@media(max-width:940px){
  .mobile-menu{display:block}
  .nav{display:none;width:100%;flex-direction:column;align-items:stretch}
  .nav.open{display:flex}
  .header-inner{flex-wrap:wrap}
  .hero{grid-template-columns:1fr}
  .hero-image{min-height:280px;order:-1}
  .hero-image img{border-radius:0;height:340px;object-fit:contain}
  .hero-copy{padding:2rem 1rem}
  .action-strip{grid-template-columns:repeat(2,1fr);margin-top:1rem}
  .grid-4,.grid-3,.partner-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr}
}
@media(max-width:620px){
  main{padding:0 .7rem 1rem}
  .logo img{width:150px}
  .top-tools{display:none}
  .hero-copy{padding:1.6rem 1rem}
  h1{font-size:2.1rem}
  .action-strip,.grid-4,.grid-3,.grid-2,.partner-grid{grid-template-columns:1fr}
  .section-header{display:block}
  .btn{width:100%;margin:.2rem 0}
}


/* Nish HTML Package correction: prevent family images from being cropped on inner pages */
.full-family-img {
  width:100%;
  height:100%;
  object-fit:contain !important;
  object-position:center !important;
  background:#f7fbff;
  padding:.35rem;
}
.photo-frame {
  border-radius:20px;
  background:#f7fbff;
  border:1px solid var(--border);
  padding:.35rem;
  width:100%;
  height:100%;
  object-fit:contain !important;
  object-position:center !important;
}
@media(max-width:940px){
  .hero-image img.full-family-img { height:320px; object-fit:contain !important; }
}

/* Clean family image correction: original local family images, no screenshot crops or black bands */
.hero-image img,
.hero-image img.full-family-img {
  object-fit: cover !important;
  object-position: center !important;
  background: #f7fbff !important;
  padding: 0 !important;
}
.card-img,
.photo-frame {
  object-fit: cover !important;
  object-position: center !important;
  background: #f7fbff !important;
  padding: 0 !important;
}
img[src*="family-"] {
  object-position: center !important;
}

.service-link-card{text-decoration:none;display:block;color:inherit;height:100%}
.service-link-card:focus{outline:4px solid rgba(255,209,0,.65);border-radius:18px}
.resource-pill{display:inline-flex;border-radius:999px;background:var(--lightblue);color:var(--blue);padding:.45rem .75rem;font-weight:900;margin:.2rem}
.step-list{display:grid;gap:1rem}.step{border:1px solid var(--border);border-radius:18px;padding:1rem;background:#fff}.step strong{color:var(--blue);font-size:1.1rem}
.partner-note{background:#EAF5FF;border-left:6px solid var(--blue);padding:1rem;border-radius:14px;margin:1rem 0}

/* Final QA fixes: header navigation, mobile menu, responsive layout, and image-banner cleanup support */
.header-inner{
  flex-wrap:nowrap;
}
.logo{flex:0 0 auto;line-height:0}
.nav{
  flex:1 1 auto;
  justify-content:center;
  min-width:0;
  flex-wrap:nowrap;
}
.nav a{white-space:nowrap}
.top-tools{flex:0 0 auto;white-space:nowrap}
.mobile-nav-tools{display:none}
.action-item.service-link-card{display:flex}

@media(max-width:1120px){
  .header-inner{
    flex-wrap:wrap;
    align-items:center;
  }
  .mobile-menu{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin-left:auto;
  }
  .nav{
    display:none;
    order:5;
    width:100%;
    flex:0 0 100%;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:.35rem;
    margin-top:.65rem;
    padding:.75rem;
    border:1px solid var(--border);
    border-radius:18px;
    background:#fff;
    box-shadow:var(--shadow);
  }
  .nav.open{display:flex}
  .nav a{
    display:block;
    width:100%;
    padding:.8rem .95rem;
    border-radius:12px;
  }
  .top-tools{display:none}
  .mobile-nav-tools{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:.65rem;
    margin-top:.35rem;
  }
  .mobile-nav-tools .btn{width:100%;box-shadow:none}
}

@media(max-width:940px){
  .hero{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .hero::after{
    width:90%;
    height:160px;
    right:-35%;
    bottom:-70px;
    opacity:.9;
  }
  .hero-image{
    order:-1;
    min-height:auto;
    padding:0;
  }
  .hero-image img,
  .hero-image img.full-family-img{
    height:auto !important;
    max-height:360px;
    width:100%;
    object-fit:cover !important;
    border-radius:0 0 18px 18px;
  }
}

@media(max-width:620px){
  .header-inner{gap:.7rem;padding:.6rem .7rem}
  .logo img{width:145px}
  .mobile-menu{padding:.58rem .72rem}
  .mobile-nav-tools{grid-template-columns:1fr}
  .hero-copy{padding:1.35rem .85rem 1.5rem}
  .hero p{font-size:1rem}
  .action-strip{border-radius:18px;padding:.8rem;margin:1rem 0}
  .action-item{padding:.65rem}
  .footer{border-radius:18px 18px 0 0}
}


/* Requested cleanup: News and English removed from header; preserve clean menu spacing. */
.top-tools .lang{display:none!important}
.nav a[href="news.html"]{display:none!important}


/* Added modern How It Works and Get Started page layouts */
.modern-page{max-width:none;padding:0 0 3rem;background:#fff}
.modern-page .modern-hero,.modern-page .modern-section{max-width:1220px;margin:0 auto;padding-left:1rem;padding-right:1rem}
.soft-hero{position:relative;display:grid;grid-template-columns:1fr .95fr;gap:3rem;align-items:center;min-height:545px;padding-top:3.5rem;padding-bottom:4rem;background:radial-gradient(circle at 7% 78%,rgba(0,132,61,.13),transparent 18%),radial-gradient(circle at 92% 78%,rgba(227,27,47,.13),transparent 18%),radial-gradient(circle at 86% 0,rgba(255,209,0,.2),transparent 24%),linear-gradient(180deg,#f9fcff 0%,#f1f8ff 100%);max-width:none !important}
.soft-hero .modern-copy,.soft-hero .modern-visual{max-width:610px}
.soft-hero .modern-copy{justify-self:end}
.soft-hero .modern-visual{justify-self:start}
.eyebrow{display:flex;align-items:center;gap:.45rem;margin:0 0 .7rem;color:var(--green);font-weight:900;letter-spacing:.02em}
.eyebrow span{width:20px;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--green) 0 48%,var(--yellow) 48% 76%,var(--red) 76%)}
.modern-copy h1{font-size:clamp(2.4rem,5vw,4.45rem);line-height:1.02;margin:0 0 1.4rem;color:var(--blue);letter-spacing:-.055em}
.intro{font-size:1.08rem;color:#0c2440;max-width:560px;margin:.85rem 0}.small-intro{font-size:1rem}.button-row{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem}.button-row .btn{border-radius:999px;padding:.72rem 1.25rem}
.modern-visual{position:relative}.decor-orb{position:absolute;right:-125px;top:0;width:155px;height:155px;border-radius:50%;background:rgba(255,209,0,.28);filter:saturate(.8);z-index:0}
.photo-card{position:relative;z-index:1;background:#fff;border:6px solid rgba(255,255,255,.95);border-radius:24px;box-shadow:0 25px 60px rgba(0,61,121,.12);overflow:hidden;max-width:390px;margin:0}.photo-card img{width:100%;height:310px;object-fit:cover}.large-photo-card{max-width:500px}.large-photo-card img{height:385px}.photo-card figcaption{position:absolute;left:1rem;right:1rem;bottom:1rem;background:rgba(255,255,255,.93);border-radius:16px;padding:1rem 1.2rem;color:var(--blue);font-weight:700;box-shadow:0 8px 22px rgba(0,0,0,.08)}.photo-card figcaption strong{font-size:1.05rem}
.modern-section{padding-top:4.2rem;padding-bottom:3rem}.modern-section h2{max-width:680px;font-size:clamp(2rem,4vw,3.05rem);line-height:1.08;letter-spacing:-.04em;margin:0 0 2rem;color:var(--blue)}.modern-grid{display:grid;gap:1.1rem}.steps-grid{grid-template-columns:repeat(4,1fr)}.assistant-grid,.get-card-grid{grid-template-columns:repeat(3,1fr);max-width:940px}.modern-card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 18px 35px rgba(0,61,121,.08);padding:1.45rem}.step-card{min-height:190px}.step-card b{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;font-size:1.1rem;margin-bottom:1.2rem}.modern-card h3{color:var(--blue);font-size:1.16rem;margin:.2rem 0 .55rem}.modern-card p{color:#42556d;margin:0}.mini-card i{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--softgreen);font-style:normal;margin-bottom:1.25rem}.split-section{display:grid;grid-template-columns:1fr .8fr;gap:4rem;align-items:center}.check-list{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;gap:.8rem}.check-list li{position:relative;padding-left:2rem;color:#233957}.check-list li:before{content:'✓';position:absolute;left:0;top:-.05rem;display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#d8f6e3;color:var(--green);font-weight:900}.rounded-photo{width:100%;max-width:390px;justify-self:center;border-radius:20px;box-shadow:0 25px 60px rgba(0,61,121,.12)}
.feature-strip{max-width:1500px;margin:-3rem auto 3.8rem;position:relative;z-index:4;background:linear-gradient(110deg,var(--blue),#006b7a,var(--green));border-radius:22px;display:grid;grid-template-columns:repeat(5,1fr);padding:1.5rem 1.8rem;box-shadow:0 20px 45px rgba(0,61,121,.18)}.feature-strip a{text-align:center;text-decoration:none;color:#fff;padding:.45rem 1.1rem;border-right:1px solid rgba(255,255,255,.25)}.feature-strip a:last-child{border-right:0}.feature-strip i{display:grid;place-items:center;margin:0 auto 1rem;width:58px;height:58px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--yellow),var(--green) 45%,var(--blue));font-size:1.45rem;font-style:normal}.feature-strip h3{margin:.2rem 0 .45rem;color:#fff}.feature-strip p{font-size:.93rem;margin:0;color:#eff9ff}
@media(max-width:1120px){.nav a{font-size:.9rem;padding:.5rem .55rem}}
@media(max-width:940px){.soft-hero{grid-template-columns:1fr;gap:2rem;min-height:auto;padding:2rem 1rem 3rem}.soft-hero .modern-copy,.soft-hero .modern-visual{justify-self:center;max-width:720px;width:100%}.decor-orb{right:1rem;top:-1rem;width:115px;height:115px}.steps-grid{grid-template-columns:repeat(2,1fr)}.split-section{grid-template-columns:1fr;gap:2rem}.feature-strip{grid-template-columns:repeat(2,1fr);margin:1rem 1rem 2.5rem}.feature-strip a{border-right:0;border-bottom:1px solid rgba(255,255,255,.25)}.assistant-grid,.get-card-grid{grid-template-columns:1fr 1fr}.modern-copy h1{font-size:clamp(2.25rem,8vw,3.25rem)}}
@media(max-width:620px){.modern-page .modern-hero,.modern-page .modern-section{padding-left:.85rem;padding-right:.85rem}.photo-card,.large-photo-card{max-width:100%}.photo-card img,.large-photo-card img{height:280px}.steps-grid,.assistant-grid,.get-card-grid,.feature-strip{grid-template-columns:1fr}.feature-strip{border-radius:18px;padding:1rem}.button-row .btn{width:100%}.modern-section{padding-top:3rem}.modern-section h2{font-size:2rem}.feature-strip a{border-bottom:1px solid rgba(255,255,255,.25)}}


/* Prototype access banner and passcode gate */
:root{--prototype-banner-height:42px}
body{padding-top:var(--prototype-banner-height)}
.prototype-banner{position:fixed;top:0;left:0;right:0;height:var(--prototype-banner-height);z-index:10000;display:flex;align-items:center;justify-content:center;padding:.55rem 1rem;text-align:center;background:linear-gradient(90deg,var(--blue),var(--green));color:#fff;font-size:.98rem;font-weight:900;letter-spacing:.02em;box-shadow:0 8px 18px rgba(0,61,121,.18)}
.site-header{top:var(--prototype-banner-height)}
.prototype-gate{position:fixed;inset:var(--prototype-banner-height) 0 0;z-index:9999;display:grid;place-items:center;padding:2rem 1rem;background:radial-gradient(circle at 9% 66%,rgba(0,132,61,.12),transparent 18%),radial-gradient(circle at 90% 3%,rgba(255,209,0,.20),transparent 22%),linear-gradient(135deg,#f8fbff 0%,#eef8f4 100%)}
.prototype-card{width:min(640px,100%);background:#fff;border:1px solid var(--border);border-radius:30px;box-shadow:0 26px 70px rgba(0,61,121,.18);padding:2.2rem;text-align:center}
.prototype-logo{width:min(380px,80%);margin:0 auto 1.3rem}
.prototype-kicker{text-transform:uppercase;letter-spacing:.22em;color:var(--green);font-weight:900;font-size:.88rem;margin-bottom:.65rem}
.prototype-card h1{font-size:clamp(2rem,5vw,3.45rem);line-height:1.1;margin:.2rem 0 .8rem;color:var(--blue)}
.prototype-copy{font-size:1.12rem;color:#3f5972;margin:.2rem 0 1.6rem}
.prototype-form{text-align:left;max-width:560px;margin:0 auto}
.prototype-form label{display:block;font-size:1.12rem;margin-bottom:.45rem;color:var(--dark)}
.prototype-input-row{display:grid;grid-template-columns:1fr auto;gap:.7rem;align-items:center}
.prototype-input-row input{min-height:64px;border:3px solid var(--green);border-radius:18px;font-size:1.1rem;padding:1rem 1.1rem;box-shadow:0 10px 22px rgba(0,132,61,.12)}
.prototype-input-row .btn{min-height:64px;border-radius:18px;padding:1rem 1.45rem}
.prototype-error{min-height:1.2rem;margin:.55rem 0 0;color:var(--red);font-weight:800;text-align:center}
.prototype-tags{display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap;margin-top:1.4rem}
.prototype-tags span{background:var(--softyellow);color:var(--blue);font-weight:900;border-radius:999px;padding:.55rem 1rem}
.prototype-locked body>header,.prototype-locked body>main,.prototype-locked body>footer{filter:blur(2px);pointer-events:none;user-select:none}
.prototype-locked body>.prototype-banner,.prototype-locked body>.prototype-gate{filter:none;pointer-events:auto;user-select:auto}
@media(max-width:620px){:root{--prototype-banner-height:56px}.prototype-banner{font-size:.9rem;line-height:1.2}.site-header{top:var(--prototype-banner-height)}.prototype-gate{inset:var(--prototype-banner-height) 0 0;padding:1rem}.prototype-card{padding:1.35rem;border-radius:22px}.prototype-logo{width:min(290px,90%)}.prototype-input-row{grid-template-columns:1fr}.prototype-input-row .btn{width:100%;margin:0}.prototype-card h1{font-size:2.1rem}}
