/* ==========================================================================
   TGE Trusted Helpline - Modern Minimal #6 + Hub & Spoke #9
   Generated: 2026-02-18
   ========================================================================== */

/* --- CSS Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter','Helvetica Neue',Arial,sans-serif;font-weight:400;color:#111;background:#fff;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color .2s}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:'Montserrat','Helvetica Neue',Arial,sans-serif;font-weight:900;line-height:1.15;color:#000;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h4{font-size:1.2rem}
p{margin-bottom:1rem}

/* --- Utility --- */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.accent{color:#0066FF}
.text-center{text-align:center}
.section-padding{padding:80px 0}

/* --- Skip Nav --- */
.skip-nav{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:#000;color:#fff;padding:12px 24px;z-index:10000;font-weight:700;border-radius:0 0 4px 4px}
.skip-nav:focus{top:0}

/* --- Header --- */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid #eee;transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1200px;margin:0 auto;padding:0 24px}
.logo{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.3rem;color:#000;letter-spacing:-.03em}
.logo span{color:#0066FF}
.header-phone{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.95rem;color:#000}
.header-phone svg{width:18px;height:18px}
.header-phone a{color:#000}
.header-phone a:hover{color:#0066FF}

/* Main Nav */
.main-nav{display:flex;align-items:center;gap:32px}
.main-nav a{font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.06em;color:#333;position:relative;padding:4px 0}
.main-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:#0066FF;transition:width .3s}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.main-nav a:hover{color:#000}
.nav-cta{background:#000;color:#fff !important;padding:10px 24px !important;border-radius:2px;font-size:.85rem !important;letter-spacing:.08em}
.nav-cta::after{display:none !important}
.nav-cta:hover{background:#0066FF}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:#000;transition:.3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Nav */
.mobile-nav{display:none;position:fixed;top:72px;left:0;width:100%;background:#fff;border-bottom:2px solid #000;padding:24px;z-index:999}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:14px 0;font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.06em;color:#000;border-bottom:1px solid #f0f0f0}
.mobile-nav a:last-child{border-bottom:none}

/* --- Hero Section --- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;margin-top:72px}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35;filter:grayscale(30%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:40px 24px;max-width:800px}
.hero h1{color:#fff;margin-bottom:20px;text-transform:uppercase;letter-spacing:.04em}
.hero h1 span{color:#0066FF}
.hero p{color:rgba(255,255,255,.8);font-size:1.15rem;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;border-radius:2px;transition:all .2s}
.btn-primary{background:#0066FF;color:#fff}
.btn-primary:hover{background:#0052cc;transform:translateY(-1px)}
.btn-secondary{background:transparent;color:#fff;border:2px solid #fff}
.btn-secondary:hover{background:#fff;color:#000}
.btn-dark{background:#000;color:#fff}
.btn-dark:hover{background:#0066FF}
.btn-outline{background:transparent;color:#000;border:2px solid #000}
.btn-outline:hover{background:#000;color:#fff}

/* --- Trust Bar --- */
.trust-bar{background:#fafafa;border-top:1px solid #eee;border-bottom:1px solid #eee;padding:24px 0}
.trust-bar .container{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:#333}
.trust-item svg{width:20px;height:20px;color:#0066FF}

/* --- Hub Navigation (Homepage) --- */
.hub-section{padding:100px 0;background:#fff}
.hub-section h2{text-align:center;margin-bottom:16px;text-transform:uppercase;letter-spacing:.04em}
.hub-subtitle{text-align:center;color:#666;font-size:1.05rem;margin-bottom:60px;max-width:600px;margin-left:auto;margin-right:auto}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}
.hub-card{position:relative;overflow:hidden;background:#fafafa;border:1px solid #eee;padding:0;transition:all .3s;cursor:pointer}
.hub-card:hover{border-color:#0066FF;transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,102,255,.1)}
.hub-card-img{height:200px;overflow:hidden}
.hub-card-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);transition:all .4s}
.hub-card:hover .hub-card-img img{filter:grayscale(0);transform:scale(1.05)}
.hub-card-content{padding:28px 24px}
.hub-card-content h3{font-size:1.15rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.hub-card-content p{color:#666;font-size:.9rem;line-height:1.6;margin-bottom:16px}
.hub-card-link{color:#0066FF;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:6px}
.hub-card-link svg{width:14px;height:14px;transition:transform .2s}
.hub-card:hover .hub-card-link svg{transform:translateX(4px)}

/* --- Section Styles --- */
.section-dark{background:#000;color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-light{background:#fafafa}

/* --- About Preview --- */
.about-preview{padding:100px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-text h2{text-transform:uppercase;letter-spacing:.04em;margin-bottom:20px}
.about-text p{color:#555;margin-bottom:16px}
.about-img{position:relative}
.about-img img{width:100%;filter:grayscale(10%)}
.about-img::before{content:'';position:absolute;top:-16px;left:-16px;width:100%;height:100%;border:2px solid #0066FF;z-index:-1}

/* --- Programs Overview --- */
.programs-overview{padding:100px 0;background:#000;color:#fff}
.programs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.program-card{padding:32px 24px;border:1px solid rgba(255,255,255,.15);transition:all .3s}
.program-card:hover{border-color:#0066FF;background:rgba(0,102,255,.05)}
.program-card .program-icon{width:48px;height:48px;margin-bottom:20px;color:#0066FF}
.program-card h3{font-size:1rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;color:#fff}
.program-card p{color:rgba(255,255,255,.6);font-size:.9rem;line-height:1.6;margin-bottom:16px}
.program-card a{color:#0066FF;font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}

/* --- Why Choose Us --- */
.why-us{padding:100px 0}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px}
.why-item{text-align:center;padding:24px}
.why-item .stat{font-family:'Montserrat',sans-serif;font-size:3rem;font-weight:900;color:#0066FF;margin-bottom:8px}
.why-item h4{text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.why-item p{color:#666;font-size:.9rem}

/* --- Testimonials --- */
.testimonials{padding:100px 0;background:#fafafa}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.testimonial-card{background:#fff;padding:32px;border:1px solid #eee}
.testimonial-card blockquote{font-size:1rem;color:#333;line-height:1.8;margin-bottom:20px;font-style:italic}
.testimonial-card blockquote::before{content:'\201C';font-family:'Montserrat',sans-serif;font-size:3rem;color:#0066FF;line-height:1;display:block;margin-bottom:8px;font-style:normal}
.testimonial-card cite{font-style:normal;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:#000}
.testimonial-card .program{display:block;color:#666;font-weight:400;font-size:.8rem;margin-top:4px;text-transform:none;letter-spacing:0}

/* --- Amenities Preview --- */
.amenities-preview{padding:100px 0}
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.amenities-grid img{width:100%;height:220px;object-fit:cover;filter:grayscale(20%);transition:all .4s}
.amenities-grid img:hover{filter:grayscale(0);transform:scale(1.02)}

/* --- CTA Banner --- */
.cta-banner{background:#0066FF;padding:80px 0;text-align:center}
.cta-banner h2{color:#fff;text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}
.cta-banner p{color:rgba(255,255,255,.85);font-size:1.1rem;margin-bottom:32px}
.cta-banner .btn{background:#fff;color:#000;font-weight:900}
.cta-banner .btn:hover{background:#000;color:#fff}
.cta-phone{font-family:'Montserrat',sans-serif;font-size:2.2rem;font-weight:900;color:#fff;margin-bottom:8px}
.cta-phone a{color:#fff}
.cta-phone a:hover{opacity:.85}

/* --- Return to Hub Button --- */
.return-hub{position:fixed;bottom:24px;right:24px;width:52px;height:52px;background:#000;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:900;opacity:0;visibility:hidden;transition:all .3s;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.return-hub.visible{opacity:1;visibility:visible}
.return-hub:hover{background:#0066FF;transform:scale(1.05)}
.return-hub svg{width:20px;height:20px}

/* --- Inner Page Hero --- */
.page-hero{background:#000;padding:120px 0 60px;margin-top:72px}
.page-hero h1{color:#fff;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,.7);font-size:1.05rem;max-width:600px}

/* --- Breadcrumbs --- */
.breadcrumbs{padding:16px 0;background:#fafafa;border-bottom:1px solid #eee;font-size:.85rem}
.breadcrumbs a{color:#666}
.breadcrumbs a:hover{color:#0066FF}
.breadcrumbs span{color:#999;margin:0 8px}
.breadcrumbs .current{color:#000;font-weight:700}

/* --- Content Sections --- */
.content-section{padding:80px 0}
.content-section h2{text-transform:uppercase;letter-spacing:.04em;margin-bottom:24px}
.content-section p{color:#555;max-width:800px}
.content-section.alt{background:#fafafa}

/* Two Column Layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.two-col.reverse{direction:rtl}
.two-col.reverse>*{direction:ltr}

/* --- Team Section --- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:40px}
.team-card{text-align:center;padding:32px 24px;border:1px solid #eee;transition:border-color .3s}
.team-card:hover{border-color:#0066FF}
.team-card h4{margin-top:16px;text-transform:uppercase;letter-spacing:.04em}
.team-card .role{color:#0066FF;font-size:.85rem;font-weight:700;margin-top:4px}
.team-card p{color:#666;font-size:.9rem;margin-top:12px}

/* --- FAQ Accordion --- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid #eee}
.faq-question{width:100%;text-align:left;padding:20px 0;font-weight:700;font-size:1rem;color:#000;display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:none;border:none;font-family:inherit}
.faq-question svg{width:20px;height:20px;transition:transform .3s;flex-shrink:0;margin-left:16px}
.faq-item.active .faq-question svg{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0}
.faq-answer-inner{padding:0 0 20px;color:#555;line-height:1.8}

/* --- Insurance Grid --- */
.insurance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.insurance-item{padding:16px 20px;border:1px solid #eee;font-weight:700;font-size:.9rem;text-align:center;transition:border-color .3s}
.insurance-item:hover{border-color:#0066FF}

/* --- Step Process --- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:48px}
.step{text-align:center;position:relative}
.step-number{font-family:'Montserrat',sans-serif;font-size:3rem;font-weight:900;color:#0066FF;margin-bottom:12px}
.step h4{text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.step p{color:#666;font-size:.9rem}
.step::after{content:'';position:absolute;top:24px;right:-16px;width:32px;height:2px;background:#eee}
.step:last-child::after{display:none}

/* --- Blog Grid --- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.blog-card{border:1px solid #eee;overflow:hidden;transition:all .3s}
.blog-card:hover{border-color:#0066FF;transform:translateY(-2px)}
.blog-card-img{height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);transition:all .4s}
.blog-card:hover .blog-card-img img{filter:grayscale(0)}
.blog-card-content{padding:24px}
.blog-card-category{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#0066FF;margin-bottom:8px}
.blog-card-content h3{font-size:1rem;margin-bottom:8px}
.blog-card-content p{color:#666;font-size:.9rem;margin-bottom:12px}
.blog-card-date{color:#999;font-size:.8rem}

/* --- Contact Grid --- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:48px}
.contact-info-item{display:flex;gap:16px;margin-bottom:24px}
.contact-info-item svg{width:24px;height:24px;flex-shrink:0;color:#0066FF}
.contact-info-item h4{font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.contact-info-item p{color:#555;font-size:.9rem}
.contact-info-item a{color:#0066FF;font-weight:700}

/* Map */
.map-container{margin-top:48px;border:1px solid #eee;overflow:hidden}
.map-container iframe{width:100%;height:450px;border:0}

/* --- Footer --- */
.site-footer{background:#000;color:#fff;padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-brand .logo{font-size:1.4rem;margin-bottom:16px}
.footer-brand .logo span{color:#0066FF}
.footer-brand p{color:rgba(255,255,255,.5);font-size:.9rem;line-height:1.7;margin-bottom:20px}
.footer-col h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-bottom:20px}
.footer-col a{display:block;color:rgba(255,255,255,.5);font-size:.9rem;margin-bottom:10px;transition:color .2s}
.footer-col a:hover{color:#0066FF}
.footer-bottom{margin-top:60px;padding:24px 0;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:#0066FF}

/* --- Privacy Page --- */
.privacy-content{padding:60px 0}
.privacy-content h2{font-size:1.4rem;margin-top:40px;margin-bottom:16px}
.privacy-content h3{font-size:1.1rem;margin-top:24px;margin-bottom:12px}
.privacy-content p,.privacy-content li{color:#555;font-size:.95rem;line-height:1.8}
.privacy-content ul{padding-left:24px;margin-bottom:16px}
.privacy-content ul li{list-style:disc;margin-bottom:8px}

/* --- HIPAA Notice --- */
.hipaa-notice{display:flex;gap:16px;align-items:flex-start;background:#fafafa;border:1px solid #eee;padding:24px;margin:32px 0;font-size:.9rem;color:#555}
.hipaa-notice svg{flex-shrink:0;color:#0066FF}
.hipaa-notice strong{color:#000}

/* --- Contact Card (no icon) --- */
.contact-card{padding:32px 28px;border:1px solid #eee;transition:border-color .3s}
.contact-card:hover{border-color:#0066FF}
.contact-card h4{font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.contact-card p{color:#555;font-size:.9rem}
.contact-card a{color:#0066FF;font-weight:700}
.contact-card ol{padding-left:18px;line-height:1.9;color:#555;font-size:.9rem}
.contact-card ol li{list-style:decimal}

/* --- Responsive --- */
@media(max-width:1024px){
  .hub-grid{grid-template-columns:repeat(2,1fr)}
  .programs-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step::after{display:none}
}
@media(max-width:768px){
  .main-nav{display:none}
  .hamburger{display:flex}
  .hero{min-height:85vh}
  .hub-grid{grid-template-columns:1fr}
  .programs-grid{grid-template-columns:1fr}
  .about-grid,.two-col,.contact-grid{grid-template-columns:1fr;gap:32px}
  .two-col.reverse{direction:ltr}
  .testimonials-grid{grid-template-columns:1fr}
  .amenities-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .insurance-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .why-grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:center}
  .section-padding{padding:60px 0}
  .about-img::before{display:none}
  .cta-phone{font-size:1.6rem}
}
@media(max-width:480px){
  .amenities-grid{grid-template-columns:1fr}
  .insurance-grid{grid-template-columns:1fr}
  .trust-bar .container{flex-direction:column;gap:16px;align-items:center}
}
