/*
 Theme Name:   MSP Mesh Child
 Template:     Divi
 Author:       Twin Cities Mesh
 Description:  Divi child theme for the Twin Cities Mesh site — single source of
               truth for design tokens, light/dark mode, fonts, buttons, and the
               Divi-neutralizing rules. Replaces all per-page and Theme-Options CSS.
 Version:      1.0
*/
/* ===== Twin Cities Mesh — shared theme (light + dark, WCAG 2.1 AA) =====
   Used by every page, the way a Divi Theme Builder + global CSS would be. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap');
:root{
  --font:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-display:'Space Grotesk','Inter',system-ui,sans-serif;
  /* brand fills — stay bright in BOTH modes (always carry dark text or are purely decorative) */
  --accent:#39d98a; --accent2:#3aa0ff; --on-green:#06281a; --on-blue:#021428;
  --radius:16px; --maxw:1140px;
  /* DARK theme (default) */
  --bg:#0b0f14; --bg2:#111823; --card:#161f2c; --line:#243245;
  --ink:#e8eef6; --muted:#9fb0c3;
  --link:#3aa0ff; --link-2:#39d98a;          /* accessible link text (AA verified) */
  --grad1:#39d98a; --grad2:#3aa0ff;          /* gradient heading text */
  --warn-text:#ffcf5c; --warn:#ffcf5c;
  --nav-bg:rgba(11,15,20,.72); --pill-bg:#0b1320;
  --chip-do-bg:rgba(57,217,138,.10); --chip-do-bd:rgba(57,217,138,.32); --chip-do-tx:#bff3d8;
  --chip-dont-bg:rgba(255,107,107,.09); --chip-dont-bd:rgba(255,107,107,.30); --chip-dont-tx:#ffc9c9;
  font-synthesis:none;
}
/* LIGHT theme — values chosen to pass WCAG 2.1 AA (4.5:1 text) */
:root[data-theme="light"]{
  --bg:#ffffff; --bg2:#eef2f7; --card:#f4f7fb; --line:#dbe3ec;
  --ink:#10212e; --muted:#48586a;
  --link:#0a6cce; --link-2:#0b7a48;
  --grad1:#0b7a48; --grad2:#0a6cce;
  --warn-text:#8a6a00; --warn:#caa53a;
  --nav-bg:rgba(255,255,255,.80); --pill-bg:#eef2f7;
  --chip-do-bg:#dff3e8; --chip-do-bd:#9ed8ba; --chip-do-tx:#0e3b27;
  --chip-dont-bg:#fbe3e3; --chip-dont-bd:#e8b0b0; --chip-dont-tx:#7a1d1d;
}
/* respect the OS preference when the visitor hasn't manually chosen */
@media (prefers-color-scheme: light){
  :root:not([data-theme]){
    --bg:#ffffff; --bg2:#eef2f7; --card:#f4f7fb; --line:#dbe3ec;
    --ink:#10212e; --muted:#48586a;
    --link:#0a6cce; --link-2:#0b7a48;
    --grad1:#0b7a48; --grad2:#0a6cce;
    --warn-text:#8a6a00; --warn:#caa53a;
    --nav-bg:rgba(255,255,255,.80); --pill-bg:#eef2f7;
    --chip-do-bg:#dff3e8; --chip-do-bd:#9ed8ba; --chip-do-tx:#0e3b27;
    --chip-dont-bg:#fbe3e3; --chip-dont-bd:#e8b0b0; --chip-dont-tx:#7a1d1d;
  }
}
html{color-scheme:light dark}
/* WCAG 2.4.7 — visible keyboard focus */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--link); outline-offset:2px; border-radius:6px;
}
/* WCAG 2.3.3 — honor reduced-motion */
@media (prefers-reduced-motion: reduce){*{animation:none !important; transition:none !important; scroll-behavior:auto !important}}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,rgba(58,160,255,.12),transparent),
     radial-gradient(1000px 500px at 0% 0%,rgba(57,217,138,.10),transparent),var(--bg);
     color:var(--ink);font-family:var(--font);line-height:1.55;
     -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em;font-weight:700}
a{color:inherit;text-decoration:none}
/* skip link — WCAG 2.4.1 */
.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:#04121e;padding:10px 16px;border-radius:0 0 10px 0;z-index:100;font-weight:700}
.skip:focus{left:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
/* unified button system: green primary + clean outline (everything else) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:13px 24px;min-height:48px;font-weight:600;font-size:15px;line-height:1.2;border:1px solid transparent;cursor:pointer;transition:.18s}
.btn-primary{background:var(--accent);color:var(--on-green)}
.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-ghost,.btn-blue{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover,.btn-blue:hover{border-color:var(--accent);transform:translateY(-1px)}

/* event banner */
.eventbar{background:linear-gradient(90deg,rgba(57,217,138,.18),rgba(58,160,255,.18));border-bottom:1px solid var(--line);font-size:14px}
.eventbar .wrap{display:flex;align-items:center;gap:14px;padding:9px 22px;flex-wrap:wrap}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(57,217,138,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(57,217,138,.6)}70%{box-shadow:0 0 0 10px rgba(57,217,138,0)}100%{box-shadow:0 0 0 0 rgba(57,217,138,0)}}
.eventbar a.rsvp{margin-left:auto;color:var(--link-2);font-weight:650}

/* nav */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:var(--nav-bg);border-bottom:1px solid var(--line)}
header.nav .wrap{display:flex;align-items:center;gap:18px;padding:13px 22px}
.logo{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:.3px}
.logo .mark{width:30px;height:30px;border-radius:9px;background:conic-gradient(from 210deg,var(--accent),var(--accent2));display:grid;place-items:center;color:#04121e;font-size:15px}
nav.links{display:flex;gap:22px;margin-left:8px;font-size:14.5px;color:var(--muted)}
nav.links a:hover{color:var(--ink)}
nav.links a[aria-current="page"]{color:var(--ink);font-weight:700}
.nav-cta{margin-left:auto;display:flex;gap:10px}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:8px 12px;cursor:pointer}
.theme-toggle{margin-left:8px;background:none;border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:8px 11px;cursor:pointer;font-size:15px;line-height:1}
.theme-toggle:hover{border-color:var(--accent2)}

/* hero */
.hero{padding:74px 0 40px}
.hero.sub{padding:54px 0 8px}
.hero h1{font-size:clamp(34px,5.2vw,60px);line-height:1.04;margin:0 0 18px;letter-spacing:-.5px}
.hero.sub h1{font-size:clamp(30px,4.4vw,46px)}
.hero h1 .grad{background:linear-gradient(90deg,var(--grad1),var(--grad2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:clamp(17px,2vw,21px);color:var(--muted);max-width:660px;margin:0 0 28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.crumb{color:var(--muted);font-size:13px;margin-bottom:14px}
.crumb a{color:var(--link)}
.stats{display:flex;gap:34px;margin-top:42px;flex-wrap:wrap}
.stat b{display:block;font-size:30px;font-weight:800;background:linear-gradient(90deg,var(--grad1),var(--grad2));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--muted);font-size:13.5px;text-transform:uppercase;letter-spacing:1px}

section{padding:56px 0}
.sec-head{margin-bottom:30px}
.sec-head .kicker{color:var(--link-2);font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase}
.sec-head h2{font-size:clamp(26px,3.4vw,38px);margin:8px 0 8px;letter-spacing:-.4px}
.sec-head p{color:var(--muted);max-width:680px;margin:0}

.grid{display:grid;gap:18px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:1.15fr .85fr}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.card h3{margin:6px 0 8px;font-size:18px}
.card p{color:var(--muted);margin:0;font-size:14.5px}
.ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:20px;background:rgba(58,160,255,.13);border:1px solid var(--line)}

/* steps */
.steps{counter-reset:s}
.step{display:flex;gap:18px;padding:20px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:0}
.step .n{counter-increment:s;flex:0 0 44px;height:44px;border-radius:12px;display:grid;place-items:center;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#04121e}
.step .n::before{content:counter(s)}
.step h4{margin:4px 0 5px;font-size:17px}
.step p{color:var(--muted);margin:0;font-size:14.5px}
.pill{display:inline-block;font-size:12px;color:var(--link-2);border:1px solid var(--line);border-radius:999px;padding:2px 10px;margin-top:8px}

/* setup tabs & detail */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tab{padding:10px 18px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--muted);cursor:pointer;font-weight:600;font-size:14.5px}
.tab.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#04121e;border-color:transparent}
.tabpane{display:none;animation:fade .25s}
.tabpane.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.setting{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--line)}
.setting:last-child{border-bottom:0}
.setting .k{flex:0 0 30px;height:30px;border-radius:8px;display:grid;place-items:center;font-weight:800;font-size:13px;background:rgba(57,217,138,.14);border:1px solid var(--line);color:var(--link-2)}
.setting h4{margin:2px 0 5px;font-size:15.5px}
.setting p{margin:0;color:var(--muted);font-size:14px}
.path{display:inline-block;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;background:var(--pill-bg);border:1px solid var(--line);border-radius:6px;padding:2px 8px;color:var(--link);margin:3px 0}
.callout{border-left:3px solid var(--warn);background:rgba(255,207,92,.08);border-radius:0 10px 10px 0;padding:12px 16px;margin-top:16px;font-size:14px;color:var(--ink)}
.callout.tip{border-left-color:var(--accent);background:rgba(57,217,138,.08)}
details.acc{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden;background:var(--card)}
details.acc summary{cursor:pointer;padding:15px 18px;font-weight:650;list-style:none;font-size:15px}
details.acc summary::-webkit-details-marker{display:none}
details.acc summary::after{content:'+';float:right;color:var(--link-2);font-weight:800;font-size:18px;line-height:1}
details.acc[open] summary::after{content:'\2013'}
details.acc .body{padding:0 18px 16px;color:var(--muted);font-size:14.5px}
details.acc .body ul{margin:6px 0 0;padding-left:20px}
details.acc .body li{margin:4px 0}
.devgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:14px}
.dev{border:1px solid var(--line);border-radius:14px;padding:16px;background:var(--card)}
.dev h4{margin:8px 0 3px;font-size:16px}
.dev .price{color:var(--link-2);font-weight:700;font-size:13px}
.dev ul{margin:9px 0 0;padding-left:18px;color:var(--muted);font-size:13px}
.dev li{margin:3px 0}

/* do / don't chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 0}
.chip{font-size:12.5px;border-radius:9px;padding:6px 11px;border:1px solid var(--line);display:inline-flex;gap:7px;align-items:flex-start;line-height:1.35;max-width:100%}
.chip.do{background:var(--chip-do-bg);border-color:var(--chip-do-bd);color:var(--chip-do-tx)}
.chip.dont{background:var(--chip-dont-bg);border-color:var(--chip-dont-bd);color:var(--chip-dont-tx)}
/* comparison table */
.cmp-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--line)}
.cmp{width:100%;border-collapse:collapse;font-size:14px;min-width:420px}
.cmp th,.cmp td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{background:var(--bg2);font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.cmp td:first-child,.cmp th:first-child{color:var(--ink);font-weight:600}
.cmp td{color:var(--muted)}
.cmp tbody tr:last-child td{border-bottom:0}
.cmp .hl{color:var(--link-2);font-weight:700}
/* physics explainer */
.why{background:linear-gradient(120deg,rgba(58,160,255,.12),rgba(57,217,138,.08));border:1px solid var(--line);border-radius:18px;padding:26px;margin-top:8px}
.why .viz{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.why .vcard{flex:1;min-width:220px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.barrow{display:flex;align-items:center;gap:10px;margin:9px 0}
.barlabel{flex:0 0 110px;font-size:12px;color:var(--muted)}
.bartrack{flex:1;height:9px;background:var(--pill-bg);border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.barfill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent2),var(--accent))}

/* device / qr */
.device{display:flex;gap:18px;align-items:flex-start}
.qr{flex:0 0 132px}
.qr .qrbox{width:132px;height:132px;border-radius:14px;background:#fff;display:grid;place-items:center;padding:10px}
.qr small{display:block;text-align:center;color:var(--muted);margin-top:8px;font-size:12px}
.best{border:1px solid var(--accent);box-shadow:0 0 0 3px rgba(57,217,138,.10)}
.tag-best{display:inline-block;background:var(--accent);color:#04121e;font-weight:700;font-size:11px;padding:3px 10px;border-radius:999px;letter-spacing:.5px}

/* map */
.mapframe{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg2);height:480px}
.mapframe.preview{height:300px}
.mapframe iframe{width:100%;height:100%;border:0;display:block}
.map-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}

/* events list */
.ev{display:flex;gap:16px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--card)}
.ev .date{flex:0 0 64px;text-align:center;border-radius:12px;background:var(--bg2);border:1px solid var(--line);padding:8px 0}
.ev .date b{display:block;font-size:22px}
.ev .date span{font-size:11px;color:var(--muted);text-transform:uppercase}
.ev h4{margin:0 0 3px}
.ev p{margin:0;color:var(--muted);font-size:14px}
.ev .when{margin-left:auto;text-align:right;color:var(--muted);font-size:13px}

/* involve */
.involve .card{display:flex;flex-direction:column}
.involve .card .btn{margin-top:14px;align-self:flex-start}

/* discord */
.discord{display:flex;align-items:center;gap:26px;background:linear-gradient(120deg,rgba(88,101,242,.18),rgba(58,160,255,.10));border:1px solid var(--line);border-radius:20px;padding:30px;flex-wrap:wrap}
.discord .big{font-size:40px;font-weight:800;background:linear-gradient(90deg,var(--grad1),var(--grad2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* cross-page "next step" band */
.next{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px}

footer{border-top:1px solid var(--line);padding:34px 0;color:var(--muted);font-size:13.5px}
footer .wrap{display:flex;gap:24px;flex-wrap:wrap;align-items:
/* =====================================================================
   Divi integration — neutralize Divi's defaults so the tokens above own
   100% of color/layout. This is what makes dark mode reliable AND lets
   us delete the per-page embedded CSS (single source of truth).
   ===================================================================== */
#et-main-area .et_pb_section{ background:transparent !important; padding:0 !important; }
#et-main-area .et_pb_row{ width:100% !important; max-width:none !important; margin:0 !important; padding:0 !important; }
#et-main-area .et_pb_column{ width:100% !important; margin:0 !important; }
#et-main-area .et_pb_module.et_pb_code, #et-main-area .et_pb_code_inner{ margin:0 !important; }
/* headings + body text follow the tokens & fonts (Divi forces #333 / Segoe) */
#et-main-area h1,#et-main-area h2,#et-main-area h3,#et-main-area h4,#et-main-area h5,#et-main-area h6{ color:var(--ink) !important; font-family:var(--font-display) !important; }
#et-main-area, #et-main-area p, #et-main-area li, #et-main-area a, #et-main-area .btn, #et-main-area input, #et-main-area td, #et-main-area th{ font-family:var(--font) !important; }
#et-main-area .grad, #et-main-area .stat b, #et-main-area .discord .big{ color:transparent !important; }
/* default global header/footer hidden — each page ships its own (move to Theme Builder long-term) */
#main-header, #top-header, #main-footer{ display:none !important; }
#page-container{ padding-top:0 !important; }
