/* ===== Savvy Senior Tech Hub — main stylesheet ===== */
:root{
  --navy:#0b1437;
  --navy-2:#101a44;
  --orange:#e89b2e;
  --orange-dark:#c97f15;
  --violet:#5b3df5;
  --ink:#1a1d2e;
  --ink-soft:#475066;
  --bg:#ffffff;
  --bg-soft:#f7f8fb;
  --bg-dark:#0b1437;
  --line:#e6e8ef;
  --accent-yellow:#ffd166;
  --shadow-sm:0 4px 10px rgba(11,20,55,.06);
  --shadow-md:0 18px 40px -12px rgba(11,20,55,.18);
  --r:14px;
  --container:1200px;
  --serif:"Playfair Display", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block;border-radius:10px}
a{color:var(--orange-dark);text-decoration:none}
a:hover{color:var(--orange)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container.narrow{max-width:780px}
.text-center{text-align:center}

h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.15;font-weight:600;margin:0 0 .6em}
.display{font-family:var(--serif);font-weight:600;letter-spacing:-.01em}
h1.display, .display{font-size:clamp(2rem, 4.4vw, 3.6rem)}
h2.display{font-size:clamp(1.7rem, 3.2vw, 2.6rem)}
em{font-style:italic;color:var(--orange-dark)}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;color:var(--violet);margin:0 0 .9rem}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}

/* ===== Top bar ===== */
.topbar{background:#f1f1f5;color:var(--violet);font-size:.82rem;letter-spacing:.12em;font-weight:600;text-transform:uppercase}
.topbar .container{padding-top:10px;padding-bottom:10px;text-align:right}

/* ===== Header ===== */
.site-header{position:relative;background:#fff}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 24px}
.site-branding .logo-fallback{display:inline-block;background:var(--navy);color:#fff;padding:18px 22px;border-radius:6px;text-align:center;font-family:var(--sans);text-decoration:none;line-height:1}
.site-branding .logo-mark{display:block;font-weight:700;letter-spacing:.08em;font-size:.78rem}
.site-branding .logo-sub{display:block;font-weight:500;letter-spacing:.16em;font-size:.62rem;margin-top:4px;opacity:.85}
.site-branding img{max-height:80px;width:auto}
.site-nav{display:flex;align-items:center;gap:38px}
.primary-menu{list-style:none;display:flex;gap:38px;margin:0;padding:0}
.primary-menu a{color:var(--ink);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.86rem;padding:6px 0;border-bottom:2px solid transparent}
.primary-menu .current-menu-item > a, .primary-menu a:hover{color:var(--orange-dark);border-color:var(--orange)}
.header-cta{white-space:nowrap}
.header-divider{height:30px;background:linear-gradient(to bottom right,#fff 49%,transparent 50%) bottom right/50% 100% no-repeat,
                                 linear-gradient(to bottom left, #fff 49%,transparent 50%) bottom left/50% 100% no-repeat,
                                 #f7f8fb}

/* Mobile nav */
.nav-toggle{display:none;background:transparent;border:0;padding:10px;cursor:pointer}
.nav-toggle .bar{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;transition:.2s}

/* ===== Buttons ===== */
.btn{display:inline-block;padding:14px 26px;border-radius:6px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.82rem;border:2px solid transparent;cursor:pointer;transition:transform .15s ease, background .15s ease, color .15s ease}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-dark);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}

/* ===== Hero ===== */
.hero{position:relative;background:linear-gradient(180deg,#fbfaf6 0%,#fff 100%);overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:center;padding:80px 24px 120px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-art{display:flex;justify-content:center}
.globe-card{background:var(--navy);color:#fff;width:240px;height:240px;border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:.78rem;letter-spacing:.18em;box-shadow:var(--shadow-md)}
.globe-card strong{font-size:.95rem;letter-spacing:.22em}
.globe{width:120px;height:120px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);position:relative;margin-bottom:16px;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.18), transparent 60%)}
.globe::before,.globe::after{content:"";position:absolute;inset:0;border:1.5px solid rgba(255,255,255,.6);border-radius:50%}
.globe::before{transform:rotateX(70deg)}
.globe::after{transform:rotateY(70deg)}

/* ===== Sections ===== */
.section{padding:84px 0}
.section-light{background:var(--bg-soft)}
.section-dark{background:var(--bg-dark);color:#e9ecf6}
.section-dark h2,.section-dark h3,.section-dark blockquote{color:#fff}
.section-dark .eyebrow{color:var(--accent-yellow)}
.section-dark cite{color:var(--accent-yellow);font-style:normal;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}
.section-head{max-width:780px;margin:0 auto 48px}
.section-head.center{text-align:center}
.section-head .lead{margin:0 auto}

.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.feature-card{background:#fff;border-radius:var(--r);padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .2s ease, box-shadow .2s ease}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feature-icon{font-size:2rem;margin-bottom:14px}
.feature-card h3{font-size:1.3rem;margin-bottom:.4em}

/* Two col */
.two-col{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:center}
.section-host{background:#fff}
.host-photo .photo-frame{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-md);max-width:380px;margin:0 auto}
.host-photo img{width:100%;height:100%;display:block;border-radius:0}

/* Service blocks */
.service-block{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;margin:64px 0;padding:32px;background:#fff;border-radius:var(--r);box-shadow:var(--shadow-sm)}
.service-block.reverse{grid-template-columns:1fr 1.1fr}
.service-block.reverse .service-text{order:2}
.service-block.reverse .service-img{order:1}
.service-tag{display:inline-block;background:var(--accent-yellow);color:var(--ink);font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;border-radius:999px;margin-bottom:14px}
.service-text h2,.service-text h3{margin-top:0}
.check-list{list-style:none;padding:0;margin:1rem 0 0}
.check-list li{padding:10px 0 10px 32px;position:relative;border-bottom:1px solid var(--line)}
.check-list li:last-child{border-bottom:0}
.check-list li::before{content:"✓";position:absolute;left:0;top:10px;width:22px;height:22px;background:var(--orange);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}
.service-img img{border-radius:var(--r)}

/* Testimonials */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testimonials blockquote{background:rgba(255,255,255,.06);border-left:3px solid var(--orange);margin:0;padding:28px;border-radius:10px}
.testimonials blockquote p{margin:0 0 1rem;font-style:italic}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--orange) 0%,#f0b14b 100%);color:#fff;padding:64px 0}
.cta-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px}
.cta-inner h2{color:#fff;margin:0}
.cta-inner p{margin:0;color:#fff}
.cta-inner .btn-primary{background:var(--navy);color:#fff}
.cta-inner .btn-primary:hover{background:#000}
.cta-inner a{color:#fff;text-decoration:underline}

/* Page hero (interior pages) */
.page-hero{background:linear-gradient(180deg,#fbfaf6 0%,#fff 100%);padding:80px 0 40px}
.page-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);margin:0 0 .5em}

/* About help grid */
.help-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.help-grid li{background:#fff;border:1px solid var(--line);padding:18px 20px 18px 48px;border-radius:10px;position:relative;box-shadow:var(--shadow-sm)}
.help-grid li::before{content:"★";position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--orange);font-size:1.1rem}

/* Forms */
.savvy-form{display:flex;flex-direction:column;gap:14px;background:#fff;padding:28px;border-radius:var(--r);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.savvy-form label{display:flex;flex-direction:column;font-weight:600;font-size:.9rem;color:var(--ink)}
.savvy-form input,.savvy-form textarea{margin-top:6px;border:1.5px solid var(--line);border-radius:8px;padding:12px 14px;font-family:inherit;font-size:1rem;background:#fff;color:var(--ink)}
.savvy-form input:focus,.savvy-form textarea:focus{outline:none;border-color:var(--orange)}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-success{background:#e7f7ec;border:1px solid #9ad0a8;color:#1f6a37;padding:12px 16px;border-radius:8px}
.form-error{background:#fdecec;border:1px solid #e0a4a4;color:#a13030;padding:12px 16px;border-radius:8px}

.contact-grid{align-items:start}

/* Footer */
.site-footer{background:var(--navy);color:#cfd4e6;padding:56px 0 24px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.footer-title{color:#fff;font-family:var(--serif);font-size:1.15rem;margin:0 0 12px}
.site-footer a{color:#fff}
.site-footer a:hover{color:var(--orange)}
.footer-menu{list-style:none;padding:0;margin:0}
.footer-menu li{padding:4px 0}
.footer-bottom{margin-top:36px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);color:#9aa3bf;font-size:.85rem}

/* ===== Responsive ===== */
@media (max-width: 960px){
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:60px 24px 80px}
  .hero-cta{justify-content:center}
  .three-col,.testimonials{grid-template-columns:1fr;gap:18px}
  .two-col{grid-template-columns:1fr;gap:32px}
  .service-block,.service-block.reverse{grid-template-columns:1fr;padding:20px}
  .service-block.reverse .service-text{order:1}.service-block.reverse .service-img{order:2}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .help-grid{grid-template-columns:1fr}
  .form-row.two{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .topbar{font-size:.7rem;letter-spacing:.08em}
  .topbar .container{text-align:center}
  .nav-toggle{display:block;order:3}
  .site-nav{position:relative}
  .primary-menu{display:none;position:absolute;top:100%;right:0;background:#fff;flex-direction:column;gap:0;min-width:220px;box-shadow:var(--shadow-md);border-radius:10px;padding:10px 0;z-index:50}
  .primary-menu.is-open{display:flex}
  .primary-menu li{padding:0}
  .primary-menu a{display:block;padding:12px 22px;border:0}
  .header-cta{padding:10px 16px;font-size:.72rem}
  .cta-inner{flex-direction:column;text-align:center}
}
