
:root { --brand:#009193; --brand-dark:#006f72; --accent:#f06f3c; --ink:#101114; --soft:#555963; --muted:#71747c; --line:#e8e1d8; --cream:#f7f2ea; --white:#fff; --container:1180px; --radius-lg:28px; --radius-md:18px; --radius-sm:10px; --font-display: "Manrope", "Inter", "Helvetica Neue", Arial, sans-serif; --font-body: "Inter", "Helvetica Neue", Arial, sans-serif; }
*{box-sizing:border-box} html{scroll-behavior:smooth;-webkit-text-size-adjust:100%} body{margin:0;font-family:var(--font-body);color:var(--ink);background:#fff;line-height:1.55;font-size:16px} img,picture,svg{display:block;max-width:100%;height:auto} a{color:inherit;text-decoration:none} button,input,select,textarea{font:inherit} h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.05;letter-spacing:0;margin:0 0 16px;color:var(--ink)} h1{font-size:4.1rem} h2{font-size:2.55rem} h3{font-size:1.32rem} p{margin:0 0 16px;color:var(--soft)} .eyebrow{display:inline-block;margin:0 0 14px;font-family:var(--font-display);font-weight:800;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brand)} .eyebrow::after{content:" //";opacity:.55} .site-header{position:fixed;top:18px;left:0;right:0;z-index:50;display:flex;justify-content:center;pointer-events:none} .nav-pill{pointer-events:auto;display:inline-flex;align-items:center;gap:30px;width:fit-content;margin:0 auto;padding:10px 14px 10px 20px;border:1px solid rgba(16,17,20,.08);border-radius:999px;background:rgba(255,255,255,.8);backdrop-filter:blur(14px);box-shadow:0 10px 30px rgba(16,17,20,.08)} .nav-brand,.footer-brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800} .logo-mark{width:32px;height:32px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--brand),var(--accent));font-size:.82rem;font-weight:800} .nav-links{display:flex;gap:22px} .nav-links a{font-weight:700;font-size:.94rem;color:var(--ink);opacity:.84} .nav-links a:hover{opacity:1} .nav-cta{display:inline-flex;align-items:center;gap:8px;padding:9px 16px 9px 18px;border-radius:999px;background:var(--ink);color:#fff;font-weight:800} .nav-cta span{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:var(--brand)} .mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:0;background:transparent;padding:0} .mobile-menu-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:3px 0;border-radius:999px} @media(min-width:1024px){.mobile-menu-toggle{display:none!important}} .mobile-menu{position:fixed;inset:0;z-index:80;display:none;flex-direction:column;padding:82px 28px 36px;background:rgba(16,17,20,.96);color:#fff} .mobile-menu.open{display:flex} .mobile-menu a{padding:15px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:1.45rem;font-weight:800} .btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;border:0;font-weight:800;white-space:nowrap} .btn span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;background:rgba(255,255,255,.22)} .btn-primary{background:var(--brand);color:#fff} .btn-ghost{background:rgba(255,255,255,.13);color:#fff;border:1px solid rgba(255,255,255,.28)} .btn-outline{background:#fff;border:1.5px solid var(--ink);color:var(--ink)} .btn-outline span{background:var(--ink);color:#fff} .btn-light{background:#fff;color:var(--ink)} .btn-outline-light{border:1px solid rgba(255,255,255,.5);color:#fff} .hero{position:relative;min-height:760px;padding:150px 22px 80px;display:flex;align-items:center;background:#0f1114;color:#fff;overflow:hidden} .hero-media{position:absolute;inset:0;z-index:0} .hero-media img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.9} .hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,17,20,.86),rgba(16,17,20,.48) 54%,rgba(16,17,20,.18))} .hero-card{position:relative;z-index:2;max-width:650px;margin:0 auto 0 calc((100% - min(1180px, calc(100% - 44px)))/2);padding:36px;border-radius:28px;background:rgba(16,17,20,.62);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);box-shadow:0 20px 60px rgba(0,0,0,.28)} .hero h1,.hero p,.hero .eyebrow{color:#fff} .hero h1 em{font-style:italic;color:#fff2c8} .hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px} .hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px} .hero-badges span{padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.13);color:#fff;font-size:.86rem;font-weight:700} section{padding:86px 22px} .section-head{max-width:780px;margin:0 auto 38px;text-align:center} .section-head p{font-size:1.08rem} .inverse h2,.inverse p,.inverse .eyebrow{color:#fff} .proof-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;max-width:1180px;margin:-52px auto 0;position:relative;z-index:5;padding:0 22px;background:transparent} .proof-strip div{background:#fff;padding:24px;border:1px solid var(--line)} .proof-strip strong{display:block;font-size:1.35rem;font-weight:900} .proof-strip span{color:var(--muted)} .why-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px} .why-card{min-height:210px;padding:24px;border:1px solid var(--line);border-radius:18px;background:#fff} .icon-dot{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;margin-bottom:18px;border-radius:999px;background:var(--cream);color:var(--brand);font-weight:900} .split{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center;background:var(--cream)} .split>div{min-width:0} .split-photo img,.program-photo img,.service-photo img{width:100%;height:100%;max-height:640px;object-fit:cover;border-radius:28px} .split-copy{padding:16px} .check-list{list-style:none;padding:0;margin:22px 0} .check-list li{position:relative;margin:0 0 12px;padding-left:30px;color:var(--soft)} .check-list li::before{content:"";position:absolute;left:0;top:.48em;width:15px;height:15px;border-radius:999px;background:var(--brand);box-shadow:inset 0 0 0 4px #fff} .brand-band{background:var(--brand);margin:0;padding-top:92px;padding-bottom:96px} .service-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px} .service-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 14px 34px rgba(0,0,0,.12)} .service-card img{width:100%;height:190px;object-fit:cover} .service-card div{padding:22px} .text-link{display:inline-flex;margin-top:8px;font-weight:900;color:var(--brand)} .program-band,.contact-panel,.service-hero{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center} .program-band{background:#fff} .mini-grid{display:grid;grid-template-columns:auto 1fr;gap:10px 14px;margin:22px 0} .mini-grid span{color:var(--brand);font-weight:900} .testimonials-band{background:var(--cream)} .testimonial-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:18px} blockquote{margin:0;padding:26px;border-radius:18px;background:#fff;border:1px solid var(--line)} blockquote p{font-size:1.18rem;color:var(--ink)} cite{font-style:normal;color:var(--muted);font-weight:800} .contact-panel{background:var(--ink);color:#fff;border-radius:28px;padding:42px} .contact-panel h2,.contact-panel p,.contact-panel .eyebrow{color:#fff} .big-phone{display:inline-block;margin-top:10px;font-size:2.1rem;font-weight:900;color:#fff} .contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px} .contact-form label{display:flex;flex-direction:column;gap:7px;color:#fff;font-weight:800} .contact-form input,.contact-form select,.contact-form textarea{width:100%;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:13px} .contact-form option{color:var(--ink)} .wide{grid-column:1/-1} .page-hero{max-width:980px;margin:0 auto;padding-top:160px;text-align:center} .page-hero h1{font-size:3.9rem} .detail-list{max-width:1180px;margin:0 auto;display:grid;gap:28px} .detail-card{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:center;padding:24px;border-radius:24px;border:1px solid var(--line);background:#fff} .detail-card img{width:100%;height:390px;object-fit:cover;border-radius:18px} .service-hero{padding-top:160px} .image-pair{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:20px} .image-pair img{height:420px;object-fit:cover;border-radius:24px;width:100%} .faq-block{max-width:860px;margin:0 auto} details{border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:0 0 12px;background:#fff} summary{font-weight:900;cursor:pointer} .post-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px} .post-card{border:1px solid var(--line);border-radius:18px;padding:22px;background:#fff} .article-body{max-width:820px;margin:0 auto;font-size:1.1rem} .location-card{margin-top:26px;padding:22px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.08)} .location-card span{color:var(--accent);font-weight:900} .site-footer{background:#101114;color:#fff;padding:70px 22px 90px} .footer-cta,.footer-grid,.footer-bottom{max-width:1180px;margin:0 auto} .footer-cta{display:flex;justify-content:space-between;gap:30px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12)} .footer-cta h2,.footer-cta p,.footer-cta .eyebrow{color:#fff} .footer-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap} .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px;padding:42px 0} .footer-grid h3{color:#fff;font-size:1rem} .footer-grid a{display:block;color:rgba(255,255,255,.78);margin:0 0 9px} .footer-grid p{color:rgba(255,255,255,.72)} .footer-bottom{display:flex;justify-content:space-between;gap:20px;color:rgba(255,255,255,.68);border-top:1px solid rgba(255,255,255,.12);padding-top:22px} .footer-credit a{text-decoration:underline} .mobile-sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:70;height:58px} .mobile-sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900} .mobile-sticky-cta .call{background:var(--brand)} .mobile-sticky-cta .message{background:#0a0a0a} @media(max-width:1100px){h1{font-size:3.2rem} h2{font-size:2.2rem} .nav-links,.nav-cta{display:none} .nav-pill{gap:12px;padding:8px 8px 8px 16px} .proof-strip,.why-grid,.service-grid{grid-template-columns:repeat(2,1fr)} .post-grid{grid-template-columns:repeat(2,1fr)} .hero-card{margin-left:auto}} @media(max-width:760px){body{padding-bottom:58px} h1{font-size:2.55rem} h2{font-size:1.95rem} .site-header{top:10px} .nav-brand span:last-child{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis} .hero{min-height:720px;padding:110px 18px 48px} .hero-card{padding:24px;border-radius:22px} section{padding:62px 18px} .proof-strip,.why-grid,.service-grid,.split,.program-band,.contact-panel,.service-hero,.detail-card,.testimonial-grid,.image-pair,.post-grid,.footer-grid{grid-template-columns:1fr} .proof-strip{margin:0;padding:0 18px} .page-hero,.service-hero{padding-top:120px} .page-hero h1{font-size:2.65rem} .contact-panel{border-radius:22px;padding:28px} .contact-form{grid-template-columns:1fr} .footer-cta,.footer-bottom{display:block} .mobile-sticky-cta{display:flex} .service-card img,.detail-card img,.image-pair img{height:270px} .big-phone{font-size:1.6rem}}
