/*
Theme Name:   Syllable Digital
Theme URI:    https://syllableapps.com
Author:       Syllable Digital
Author URI:   https://syllableapps.com
Description:  Official WordPress theme for Syllable Digital — featuring GolfTracker and TeamStreamer. Fairway palette: forest green, warm cream, brass accents.
Version:      1.1.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License:      All Rights Reserved
Text Domain:  syllable-digital
Tags:         custom-menu, custom-logo, threaded-comments, responsive-layout, full-site-editing
*/

/* Syllable Digital — shared site styles (Fairway · Light) */
:root{
  --forest:#14241A; --forest2:#1B3024; --forest3:#22402E;
  --cream:#FCFBF6; --cream2:#F6F1E2; --card:#FFFFFF;
  --hair:#E6DEC8; --hair-d:#2C3D31;
  --brass:#9A7615; --brass-bright:#C9A24A; --leaf:#3D7A3F;
  --ink:#1A211C; --ink2:#565644; --ink3:#8E886F;
  --cream-ink:#F0E8D6; --cream-ink2:#B7AE96; --cream-ink3:#7E7864;
  --serif:"Fraunces", Georgia, serif;
  --sans:"Archivo", system-ui, sans-serif;
  --mono:"JetBrains Mono", monospace;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2.4px;text-transform:uppercase;font-weight:600}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

/* NAV */
nav{position:sticky;top:0;z-index:50;background:rgba(252,251,246,0.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:18px 40px;display:flex;align-items:center;gap:32px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:-0.3px;white-space:nowrap}
.logo .mark{width:30px;height:30px;border-radius:8px;background:var(--forest);display:grid;place-items:center;color:var(--brass-bright);font-family:var(--serif);font-weight:700;font-size:17px}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:30px;font-size:14.5px;color:var(--ink2);font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-cta{font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:0.4px;background:var(--forest);color:var(--cream);padding:10px 18px;border-radius:8px;text-transform:uppercase;white-space:nowrap}

/* PAGE HERO / TITLE BAND */
.page-hero{padding:84px 0 64px;border-bottom:1px solid var(--hair);background:linear-gradient(180deg,#FBF5E6 0%,var(--cream2) 100%);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(110% 120% at 88% -10%, rgba(154,118,21,0.09), transparent 55%);pointer-events:none}
.page-hero .inner{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--brass);margin-bottom:20px}
.page-hero h1{font-family:var(--serif);font-weight:500;font-size:54px;line-height:1.04;letter-spacing:-1.3px;color:var(--ink);max-width:18ch;text-wrap:balance}
.page-hero h1 em{font-style:italic;color:var(--brass)}
.page-hero p{margin-top:22px;font-size:18px;line-height:1.6;color:var(--ink2);max-width:60ch}
.page-hero .updated{margin-top:22px;font-family:var(--mono);font-size:12px;letter-spacing:0.6px;color:var(--ink3)}

/* BUTTONS */
.btn-brass{background:var(--brass-bright);color:var(--forest);font-weight:600;font-size:15px;padding:15px 26px;border-radius:10px;font-family:var(--sans);display:inline-flex;align-items:center;gap:9px;white-space:nowrap;box-shadow:0 14px 28px -14px rgba(154,118,21,0.55);border:none;cursor:pointer}
.btn-ghost{border:1px solid var(--hair);color:var(--ink);font-weight:500;font-size:15px;padding:15px 24px;border-radius:10px;display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}

/* LEGAL / PROSE */
.legal{padding:64px 0 96px}
.legal-grid{display:grid;grid-template-columns:230px 1fr;gap:56px;align-items:start}
.toc{position:sticky;top:104px;border-left:1px solid var(--hair);padding-left:20px}
.toc h5{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--ink3);margin-bottom:16px;font-weight:600}
.toc a{display:block;font-size:14px;color:var(--ink2);padding:7px 0;line-height:1.35;border-bottom:1px solid transparent}
.toc a:hover{color:var(--brass)}
.prose{max-width:68ch}
.prose section{padding:34px 0;border-top:1px solid var(--hair)}
.prose section:first-child{border-top:none;padding-top:0}
.prose .sec-num{font-family:var(--mono);font-size:12px;letter-spacing:1.4px;color:var(--brass);font-weight:600}
.prose h2{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:-0.5px;margin:10px 0 16px;color:var(--ink)}
.prose h3{font-family:var(--sans);font-weight:700;font-size:16px;margin:22px 0 8px;color:var(--ink)}
.prose p{font-size:16px;line-height:1.72;color:var(--ink2);margin-bottom:14px}
.prose ul{margin:0 0 16px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.prose li{position:relative;padding-left:26px;font-size:16px;line-height:1.65;color:var(--ink2)}
.prose li::before{content:"";position:absolute;left:4px;top:9px;width:7px;height:7px;border-radius:2px;background:var(--brass-bright)}
.prose a{color:var(--brass);border-bottom:1px solid var(--hair)}
.prose a:hover{border-color:var(--brass)}
.prose strong{color:var(--ink);font-weight:600}
.prose table{width:100%;border-collapse:collapse;margin:14px 0 20px;font-size:14.5px}
.prose th{font-family:var(--mono);font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink3);font-weight:600;text-align:left;padding:10px 12px;border-bottom:2px solid var(--hair);background:var(--cream2)}
.prose td{padding:10px 12px;border-bottom:1px solid var(--hair);color:var(--ink2);line-height:1.55;vertical-align:top}
.prose td:first-child{color:var(--ink);font-weight:500}
.prose tr:last-child td{border-bottom:none}
.callout{background:var(--cream2);border:1px solid var(--hair);border-radius:14px;padding:22px 24px;margin:6px 0 18px}
.callout p{margin:0;font-size:15px;color:var(--ink2)}
.callout p strong{color:var(--ink)}

/* CONTACT PAGE */
.contact-wrap{padding:64px 0 96px}
.contact-cols{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-card2{background:var(--card);border:1px solid var(--hair);border-radius:22px;padding:40px;box-shadow:0 40px 80px -52px rgba(20,36,26,0.32)}
.form{display:flex;flex-direction:column;gap:16px}
.form .field{display:flex;flex-direction:column;gap:7px}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{font-family:var(--mono);font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink3);font-weight:600}
.form input,.form textarea,.form select{font-family:var(--sans);font-size:15px;background:var(--cream2);border:1px solid var(--hair);border-radius:10px;padding:13px 15px;color:var(--ink);width:100%}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--brass)}
.form button{margin-top:4px;background:var(--forest);color:var(--cream);font-family:var(--sans);font-weight:600;font-size:15px;padding:16px;border:none;border-radius:10px;cursor:pointer}
.contact-detail{display:flex;flex-direction:column;gap:8px}
.contact-detail h2{font-family:var(--serif);font-weight:500;font-size:34px;letter-spacing:-0.6px;line-height:1.1;margin-bottom:8px}
.contact-detail p{color:var(--ink2);font-size:16px;line-height:1.62;max-width:42ch}
.detail-list{margin-top:26px;display:flex;flex-direction:column;gap:2px}
.detail-row{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-top:1px solid var(--hair)}
.detail-row .k{font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink3);font-weight:600;width:96px;flex-shrink:0;padding-top:3px}
.detail-row .v{font-size:16px;color:var(--ink);line-height:1.5}
.detail-row .v a{color:var(--brass)}
.detail-row .v small{display:block;color:var(--ink3);font-size:13px;margin-top:3px;font-family:var(--sans)}

/* FOOTER */
footer{background:var(--forest);color:var(--cream-ink2);padding:70px 0 40px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid var(--hair-d)}
.foot-brand .logo{color:#fff}
.foot-brand p{margin-top:18px;font-size:14.5px;line-height:1.6;max-width:34ch;color:var(--cream-ink3)}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--cream-ink3);margin-bottom:18px;font-weight:600}
.foot-col a{display:block;font-size:14.5px;color:var(--cream-ink2);padding:6px 0}
.foot-col a:hover{color:var(--brass-bright)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-family:var(--mono);font-size:12px;letter-spacing:0.4px;color:var(--cream-ink3)}
.foot-bot a{color:var(--cream-ink3)}.foot-bot a:hover{color:var(--brass-bright)}

@media(max-width:860px){
  .page-hero h1{font-size:40px}
  .legal-grid{grid-template-columns:1fr}
  .toc{position:static;border-left:none;border-top:1px solid var(--hair);padding-left:0;padding-top:20px}
  .contact-cols{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .nav-links a:not(.nav-cta){display:none}
}

/* ===================== PHONE MOCKUPS ===================== */
.phone{width:268px;height:548px;background:#0c1410;border-radius:42px;padding:11px;box-shadow:0 30px 70px -28px rgba(20,36,26,0.6),0 0 0 1px rgba(0,0,0,0.3);position:relative;flex-shrink:0}
.phone.sm{width:232px;height:476px;border-radius:36px;padding:9px}
.phone .notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:108px;height:24px;background:#0c1410;border-radius:0 0 16px 16px;z-index:5}
.phone.sm .notch{top:9px;width:92px;height:20px}
.screen{width:100%;height:100%;border-radius:32px;overflow:hidden;position:relative}
.phone.sm .screen{border-radius:28px}

/* GolfTracker screens */
.gt{height:100%;background:#F4EFDF;color:#1A211C;display:flex;flex-direction:column;padding-top:30px;font-family:var(--sans)}
.gt-top{padding:10px 16px 8px;display:flex;align-items:center;justify-content:space-between}
.gt-top .t{font-family:var(--serif);font-size:18px;font-weight:600;font-variant:small-caps;letter-spacing:0.3px}
.gt-seg{background:#FFFAEC;border:1px solid #E0D8BD;border-radius:999px;padding:3px;display:flex;gap:2px}
.gt-seg span{font-size:9.5px;font-weight:600;padding:4px 8px;border-radius:999px;color:#5A5A47}
.gt-seg span.on{background:#9A7615;color:#fff}
.gt-card{margin:6px 14px 0;background:#FFFAEC;border:1px solid #E0D8BD;border-radius:14px;padding:14px}
.gt-card .row1{display:flex;align-items:flex-start;justify-content:space-between}
.gt-card .lbl{font-family:var(--mono);font-size:8.5px;letter-spacing:1.4px;color:#8E886F;font-weight:700;text-transform:uppercase}
.gt-card .crs{font-family:var(--serif);font-size:15px;font-weight:600;margin-top:3px;white-space:nowrap}
.gt-card .score{font-family:var(--mono);font-size:34px;font-weight:700;line-height:0.9;letter-spacing:-1px}
.gt-card .par{font-family:var(--mono);font-size:10px;color:#3D7A3F;font-weight:700;letter-spacing:0.4px;text-align:right;margin-top:3px;white-space:nowrap}
.gt-holes{margin-top:12px;display:grid;grid-template-columns:repeat(9,1fr);gap:3px}
.gt-holes .h{aspect-ratio:1;background:#FBF5DF;border:1px solid #E0D8BD;border-radius:5px;display:grid;place-items:center;font-family:var(--mono);font-size:10px;font-weight:700}
.gt-holes .h.b{color:#3D7A3F}.gt-holes .h.r{color:#A12626}
.gt-foot9{display:flex;justify-content:space-between;margin-top:6px;font-family:var(--mono);font-size:8.5px;letter-spacing:0.6px;color:#8E886F;white-space:nowrap}
.gt-foot9 b{color:#1A211C}
.gt-list{padding:12px 14px 0;display:flex;flex-direction:column;gap:7px;flex:1}
.gt-li{display:flex;align-items:center;gap:9px;background:#FFFAEC;border:1px solid #E0D8BD;border-radius:10px;padding:8px 10px}
.gt-li .ab{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;font-family:var(--mono);font-size:9px;font-weight:700}
.gt-li .nm{flex:1;font-size:12px;font-weight:600}
.gt-li .nm small{display:block;font-family:var(--mono);font-size:8.5px;color:#8E886F;font-weight:500;margin-top:2px}
.gt-li .st{font-family:var(--mono);font-size:16px;font-weight:700;letter-spacing:-0.4px}
.gt-cta{margin:12px 14px 14px;height:42px;border-radius:11px;background:#9A7615;color:#fff;display:grid;place-items:center;font-family:var(--serif);font-variant:small-caps;font-weight:600;font-size:14px}
/* GolfTracker stats screen */
.gt-h{padding:10px 16px 4px;font-family:var(--serif);font-size:18px;font-weight:600;font-variant:small-caps}
.gt-tiles{margin:6px 14px 0;display:grid;grid-template-columns:1fr 1fr;gap:7px}
.gt-tile{background:#FFFAEC;border:1px solid #E0D8BD;border-radius:11px;padding:11px 12px}
.gt-tile .k{font-family:var(--mono);font-size:8px;letter-spacing:1.2px;color:#8E886F;font-weight:700;text-transform:uppercase}
.gt-tile .v{font-family:var(--mono);font-size:24px;font-weight:700;letter-spacing:-1px;margin-top:4px}
.gt-tile .v small{font-size:11px;color:#8E886F;letter-spacing:0}
.gt-bars{margin:12px 14px 0;background:#FFFAEC;border:1px solid #E0D8BD;border-radius:12px;padding:13px 13px 11px}
.gt-bars .bh{font-family:var(--mono);font-size:8px;letter-spacing:1.2px;color:#8E886F;font-weight:700;text-transform:uppercase;margin-bottom:9px;display:flex;justify-content:space-between}
.gt-bars .row{display:flex;align-items:flex-end;gap:5px;height:78px}
.gt-bars .bar{flex:1;background:#3D7A3F;border-radius:3px 3px 0 0;opacity:0.85}
.gt-bars .bar.lo{background:#E0D8BD}

/* TeamStreamer screens */
.ts{height:100%;background:#0F1A28;color:#EFF3F8;display:flex;flex-direction:column;padding-top:30px;font-family:var(--sans)}
.ts-top{padding:8px 18px 2px;display:flex;align-items:center;justify-content:space-between}
.ts-top .d{font-family:var(--mono);font-size:8.5px;letter-spacing:1.4px;color:#5E6F86;font-weight:600}
.ts-top .ic{width:28px;height:28px;border-radius:999px;background:#162638;border:1px solid #243A55}
.ts-wm{padding:2px 18px 10px;font-size:25px;font-weight:800;letter-spacing:-0.7px;font-family:var(--sans)}
.ts-wm b{color:#3FA0CF;font-weight:800}
.ts-sec{padding:8px 18px 4px;display:flex;justify-content:space-between;align-items:baseline}
.ts-sec .l{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;color:#5E6F86;font-weight:700}
.ts-sec .s{font-family:var(--mono);font-size:8px;letter-spacing:1px;color:#5E6F86;display:flex;gap:11px}
.ts-list{padding:0 14px;display:flex;flex-direction:column;gap:7px;flex:1}
.ts-li{background:#162638;border:1px solid #243A55;border-radius:10px;padding:9px 11px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.ts-li .nm{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700}
.ts-li .dot{width:6px;height:6px;border-radius:2px}
.ts-li .meta{margin-top:4px;margin-left:13px;font-family:var(--mono);font-size:8.5px;color:#A0AFC4;letter-spacing:0.3px}
.ts-li .sets{display:flex;align-items:center;gap:7px}
.ts-li .setcol{display:flex;flex-direction:column;align-items:center;font-family:var(--mono);font-size:10px;font-weight:700;line-height:1.05}
.ts-li .setcol .lo{color:#5E6F86}
.ts-cta{margin:12px 14px 14px;height:44px;border-radius:9px;background:#1B6B93;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
/* TeamStreamer live screen */
.ts-video{margin:6px 14px 0;height:188px;border-radius:14px;overflow:hidden;position:relative;background:repeating-linear-gradient(45deg,#0a121d 0 8px,#0e1826 8px 16px);border:1px solid #243A55}
.ts-live-tag{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:5px;background:#C13B3B;color:#fff;font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:1px;padding:3px 7px;border-radius:4px}
.ts-live-tag .pulse{width:5px;height:5px;border-radius:999px;background:#fff}
.ts-views{position:absolute;top:10px;right:10px;background:rgba(0,0,0,0.55);color:#EFF3F8;font-family:var(--mono);font-size:8.5px;font-weight:600;padding:3px 7px;border-radius:4px}
.ts-scorebar{position:absolute;left:10px;right:10px;bottom:10px;background:rgba(8,14,22,0.86);border:1px solid #2C4A6E;border-radius:9px;padding:7px 9px;display:flex;align-items:center;gap:9px}
.ts-scorebar .team{flex:1;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700}
.ts-scorebar .sq{width:13px;height:13px;border-radius:3px}
.ts-scorebar .sc{font-family:var(--mono);font-size:15px;font-weight:700}
.ts-scorebar .vs{font-family:var(--mono);font-size:8px;color:#5E6F86}
.ts-ctrls{margin:11px 14px 0;display:flex;gap:7px}
.ts-ctrls .c{flex:1;background:#162638;border:1px solid #243A55;border-radius:9px;padding:9px 0;text-align:center;font-family:var(--mono);font-size:8.5px;letter-spacing:0.6px;color:#A0AFC4;font-weight:600}
.ts-ctrls .c.on{background:#1B6B93;color:#fff;border-color:#1B6B93}
.ts-dest{margin:9px 14px 0;display:flex;flex-direction:column;gap:6px}
.ts-dest .row{display:flex;align-items:center;gap:8px;background:#162638;border:1px solid #243A55;border-radius:9px;padding:8px 11px;font-size:11px;font-weight:600}
.ts-dest .row .l{flex:1}
.ts-dest .row .on{font-family:var(--mono);font-size:8px;color:#46C28E;letter-spacing:0.6px;font-weight:700}
.ts-dest .row .sw{width:24px;height:14px;border-radius:999px;background:#1B6B93;position:relative}
.ts-dest .row .sw::after{content:"";position:absolute;width:10px;height:10px;border-radius:999px;background:#fff;top:2px;right:2px}

/* ===================== APP DETAIL PAGE ===================== */
.apphero{background:linear-gradient(180deg,#FBF5E6 0%,var(--cream2) 100%);border-bottom:1px solid var(--hair);position:relative;overflow:hidden}
.apphero::after{content:"";position:absolute;inset:0;background:radial-gradient(110% 90% at 84% 0%, rgba(154,118,21,0.10), transparent 56%);pointer-events:none}
.apphero-in{max-width:var(--maxw);margin:0 auto;padding:80px 40px 84px;display:grid;grid-template-columns:1.04fr 0.96fr;gap:56px;align-items:center;position:relative;z-index:2}
.app-kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:1.6px;text-transform:uppercase;font-weight:600;color:var(--brass)}
.app-kicker .dot{width:8px;height:8px;border-radius:3px;background:var(--brass-bright)}
.apphero h1{font-family:var(--serif);font-weight:500;font-size:62px;line-height:1.02;letter-spacing:-1.6px;color:var(--ink);margin:22px 0 0}
.apphero .tagline{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--brass);margin-top:14px}
.apphero p.lede{margin-top:20px;font-size:18px;line-height:1.62;color:var(--ink2);max-width:46ch}
.store-btns{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.store-btn{display:flex;flex-direction:column;justify-content:center;background:var(--forest);color:var(--cream);border-radius:12px;padding:11px 20px;min-width:158px}
.store-btn .t{font-family:var(--mono);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--cream-ink2)}
.store-btn .n{font-family:var(--serif);font-size:18px;font-weight:600;margin-top:1px}
.store-btn:hover{background:var(--forest2)}
.rating{display:flex;align-items:center;gap:12px;margin-top:24px;font-size:14px;color:var(--ink2)}
.stars{display:flex;gap:3px;color:var(--brass-bright);font-size:15px;letter-spacing:1px}
.rating b{color:var(--ink);font-weight:700}
.apphero .phone-wrap{display:flex;align-items:center;justify-content:center;position:relative;background:radial-gradient(130% 120% at 50% -8%, #213A2B 0%, #15271B 62%, #11211700 100%),linear-gradient(180deg,#172B1E,#11201700);background-color:#142318;border:1px solid #2A4B36;border-radius:32px;padding:52px 24px;box-shadow:0 50px 110px -46px rgba(13,24,17,0.62), inset 0 1px 0 rgba(255,255,255,0.05);overflow:hidden}
.apphero .phone-wrap::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,74,0.22),transparent 64%);top:40%;left:50%;transform:translate(-50%,-50%)}
.apphero .phone{transform:rotate(2deg);position:relative;z-index:1}

/* feature rows */
.frow{display:grid;grid-template-columns:1fr 300px;gap:60px;align-items:center;padding:60px 0;border-top:1px solid var(--hair)}
.frow.rev{grid-template-columns:300px 1fr}
.frow.rev .frow-copy{order:2}
.frow .lbl{font-family:var(--mono);font-size:11.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--brass);font-weight:600}
.frow h2{font-family:var(--serif);font-weight:500;font-size:38px;letter-spacing:-0.8px;margin:14px 0 14px;line-height:1.08;color:var(--ink);max-width:16ch}
.frow p{color:var(--ink2);font-size:16px;line-height:1.66;max-width:46ch}
.frow ul{margin-top:18px;display:flex;flex-direction:column;gap:11px;list-style:none}
.frow li{position:relative;padding-left:26px;font-size:15.5px;color:var(--ink2);line-height:1.5}
.frow li::before{content:"";position:absolute;left:3px;top:8px;width:8px;height:8px;border-radius:2px;background:var(--brass-bright)}
.frow .phone-wrap{display:flex;justify-content:center}

/* feature grid */
.feat-sec{padding:96px 0;background:var(--cream2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.feat-head{text-align:center;margin-bottom:54px}
.feat-head .eyebrow{color:var(--brass);display:block;margin-bottom:16px}
.feat-head h2{font-family:var(--serif);font-weight:500;font-size:42px;letter-spacing:-1px;color:var(--ink)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.featc{background:var(--card);border:1px solid var(--hair);border-radius:16px;padding:30px 28px}
.featc .ico{width:42px;height:42px;border-radius:11px;background:var(--cream2);border:1px solid var(--hair);display:grid;place-items:center;color:var(--brass);margin-bottom:18px}
.featc h3{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:-0.3px;color:var(--ink);margin-bottom:8px}
.featc p{font-size:14.5px;line-height:1.6;color:var(--ink2)}

/* gallery */
.gallery-sec{padding:90px 0}
.gallery-sec .feat-head{margin-bottom:46px}
.gallery{display:flex;gap:26px;justify-content:center;flex-wrap:wrap}

/* specs strip */
.specs{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:14px;overflow:hidden;margin-top:8px}
.spec{background:var(--cream2);padding:24px 26px}
.spec .k{font-family:var(--mono);font-size:10.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink3);font-weight:600}
.spec .v{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--ink);margin-top:8px;letter-spacing:-0.3px}

/* CTA band */
.cta-band{background:var(--forest);color:var(--cream-ink);padding:84px 0}
.cta-band .inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-band .eyebrow{color:var(--brass-bright);margin-bottom:18px}
.cta-band h2{font-family:var(--serif);font-weight:500;font-size:44px;letter-spacing:-1px;color:#fff;max-width:16ch;line-height:1.06}
.cta-band .store-btn{background:var(--brass-bright);color:var(--forest)}
.cta-band .store-btn .t{color:rgba(20,36,26,0.6)}
.cta-band .store-btn:hover{filter:brightness(1.05)}

@media(max-width:980px){
  .apphero-in{grid-template-columns:1fr}
  .apphero .phone-wrap{display:none}
  .apphero h1{font-size:46px}
  .frow,.frow.rev{grid-template-columns:1fr}
  .frow.rev .frow-copy{order:0}
  .frow .phone-wrap{display:none}
  .feat-grid{grid-template-columns:1fr}
  .specs{grid-template-columns:1fr 1fr}
}


/* =====================================================
   TEAMSTREAMER THEME — navy / sky-blue
   Applied when body has .page-teamstreamer (slug-based)
   or .page-template-page-teamstreamer (template-based)
   ===================================================== */
.page-teamstreamer,
.page-template-page-teamstreamer {
  --cream:#0F1A28; --cream2:#142334; --card:#17283C;
  --hair:#26415E; --hair-d:#26415E;
  --brass:#46A6D4; --brass-bright:#62B7E2; --leaf:#46C28E;
  --ink:#EFF3F8; --ink2:#A6B7CD; --ink3:#708BA6;
  --cream-ink:#EFF3F8; --cream-ink2:#A6B7CD; --cream-ink3:#7E93AC;
  --forest:#0B1624; --forest2:#142334; --forest3:#1B2D44;
}
body.page-teamstreamer,
body.page-template-page-teamstreamer {
  background: #0F1A28;
}
.page-teamstreamer nav,
.page-template-page-teamstreamer nav {
  background: rgba(15,26,40,0.86);
  border-bottom: 1px solid var(--hair);
}
.page-teamstreamer .nav-cta,
.page-template-page-teamstreamer .nav-cta {
  background: var(--brass);
  color: #06121F;
}
.page-teamstreamer .apphero,
.page-template-page-teamstreamer .apphero {
  background: linear-gradient(180deg,#17283C 0%,#0F1A28 100%);
  border-bottom: 1px solid var(--hair);
}
.page-teamstreamer .apphero h1,
.page-template-page-teamstreamer .apphero h1 { color: #fff; }
.page-teamstreamer .apphero .tagline,
.page-template-page-teamstreamer .apphero .tagline { color: var(--brass-bright); }
.page-teamstreamer .apphero p.lede,
.page-template-page-teamstreamer .apphero p.lede { color: var(--ink2); }
.page-teamstreamer .app-kicker,
.page-template-page-teamstreamer .app-kicker { color: var(--brass-bright); }
.page-teamstreamer .store-btn,
.page-template-page-teamstreamer .store-btn { background: #1C3047; border: 1px solid #2E4B68; }
.page-teamstreamer .store-btn .t,
.page-template-page-teamstreamer .store-btn .t { color: var(--ink3); }
.page-teamstreamer .store-btn .n,
.page-template-page-teamstreamer .store-btn .n { color: #fff; }
.page-teamstreamer .store-btn:hover,
.page-template-page-teamstreamer .store-btn:hover { background: #23415E; }
.page-teamstreamer .apphero .phone-wrap,
.page-template-page-teamstreamer .apphero .phone-wrap {
  background: linear-gradient(180deg,#ECF3F8,#D7E6F1);
  border: 1px solid #C4D6E4;
  box-shadow: 0 50px 110px -46px rgba(0,0,0,0.62);
}
.page-teamstreamer .apphero .phone-wrap::before,
.page-template-page-teamstreamer .apphero .phone-wrap::before {
  background: radial-gradient(circle, rgba(70,150,200,0.26), transparent 62%);
}
.page-teamstreamer .frow,
.page-template-page-teamstreamer .frow { border-top: 1px solid var(--hair); }
.page-teamstreamer .frow .lbl,
.page-template-page-teamstreamer .frow .lbl { color: var(--brass-bright); }
.page-teamstreamer .frow h2,
.page-template-page-teamstreamer .frow h2 { color: #fff; }
.page-teamstreamer .frow p,
.page-teamstreamer .frow li,
.page-template-page-teamstreamer .frow p,
.page-template-page-teamstreamer .frow li { color: var(--ink2); }
.page-teamstreamer .frow .phone-wrap,
.page-template-page-teamstreamer .frow .phone-wrap {
  background: linear-gradient(180deg,#ECF3F8,#D7E6F1);
  border: 1px solid #C4D6E4;
  border-radius: 28px;
  padding: 36px 0;
  box-shadow: 0 36px 70px -44px rgba(0,0,0,0.5);
}
.page-teamstreamer .feat-sec,
.page-template-page-teamstreamer .feat-sec {
  background: #0B1624;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.page-teamstreamer .feat-head .eyebrow,
.page-template-page-teamstreamer .feat-head .eyebrow { color: var(--brass-bright); }
.page-teamstreamer .feat-head h2,
.page-template-page-teamstreamer .feat-head h2 { color: #fff; }
.page-teamstreamer .featc,
.page-template-page-teamstreamer .featc { background: #17283C; border-color: #26415E; }
.page-teamstreamer .featc .ico,
.page-template-page-teamstreamer .featc .ico { background: #0F1E30; border-color: #284B6E; color: var(--brass-bright); }
.page-teamstreamer .featc h3,
.page-template-page-teamstreamer .featc h3 { color: #fff; }
.page-teamstreamer .featc p,
.page-template-page-teamstreamer .featc p { color: var(--ink2); }
.page-teamstreamer .gallery-sec,
.page-template-page-teamstreamer .gallery-sec { background: var(--cream); }
.page-teamstreamer .gallery,
.page-template-page-teamstreamer .gallery {
  background: linear-gradient(180deg,#ECF3F8,#D7E6F1);
  border: 1px solid #C4D6E4;
  border-radius: 28px;
  padding: 46px 26px;
  box-shadow: 0 40px 80px -50px rgba(0,0,0,0.5);
}
.page-teamstreamer .spec,
.page-template-page-teamstreamer .spec { background: #152334; }
.page-teamstreamer .spec .k,
.page-template-page-teamstreamer .spec .k { color: var(--ink3); }
.page-teamstreamer .spec .v,
.page-template-page-teamstreamer .spec .v { color: #fff; }
.page-teamstreamer .cta-band,
.page-template-page-teamstreamer .cta-band { background: #0B1624; }
.page-teamstreamer .cta-band .eyebrow,
.page-template-page-teamstreamer .cta-band .eyebrow { color: var(--brass-bright); }
.page-teamstreamer .cta-band h2,
.page-template-page-teamstreamer .cta-band h2 { color: #fff; }
.page-teamstreamer .cta-band .store-btn,
.page-template-page-teamstreamer .cta-band .store-btn { background: var(--brass); color: #06121F; border: none; }
.page-teamstreamer .cta-band .store-btn .t,
.page-template-page-teamstreamer .cta-band .store-btn .t { color: rgba(6,18,31,0.62); }
.page-teamstreamer footer,
.page-template-page-teamstreamer footer { background: var(--forest); }

/* =====================================================
   MOBILE MENU
   ===================================================== */
.nav-toggle {
  display: none;
  margin-left: auto;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  flex-direction: column;
  gap: 5px;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform 0.2s, opacity 0.2s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media(max-width:860px) {
  .nav-toggle { display: flex; }
  .nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: var(--cream);
    border-bottom: 1px solid var(--hair);
    padding: 16px 24px 20px;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .nav-links.open { display: flex; }
  .nav-links a { font-size: 16px; padding: 10px 0; width: 100%; }
  .nav-links a.nav-cta { margin-top: 8px; }
  nav { position: sticky; top: 0; }
}

/* =====================================================
   HOME PAGE STYLES
   (hero, apps section, approach, contact card)
   ===================================================== */
:root{
    --forest:#14241A; --forest2:#1B3024; --forest3:#22402E;
    --cream:#FCFBF6; --cream2:#F6F1E2; --card:#FFFFFF;
    --hair:#E6DEC8; --hair-d:#2C3D31;
    --brass:#9A7615; --brass-bright:#C9A24A; --leaf:#3D7A3F;
    --ink:#1A211C; --ink2:#565644; --ink3:#8E886F;
    --cream-ink:#F0E8D6; --cream-ink2:#B7AE96; --cream-ink3:#7E7864;
    --serif:"Fraunces", Georgia, serif;
    --sans:"Archivo", system-ui, sans-serif;
    --mono:"JetBrains Mono", monospace;
    --maxw:1180px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--sans);background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
  .eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2.4px;text-transform:uppercase;font-weight:600}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

  /* NAV */
  nav{position:sticky;top:0;z-index:50;background:rgba(252,251,246,0.84);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair)}
  .nav-in{max-width:var(--maxw);margin:0 auto;padding:18px 40px;display:flex;align-items:center;gap:32px}
  .logo{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:-0.3px;white-space:nowrap}
  .logo .mark{width:30px;height:30px;border-radius:8px;background:var(--forest);display:grid;place-items:center;color:var(--brass-bright);font-family:var(--serif);font-weight:700;font-size:17px}
  .nav-links{margin-left:auto;display:flex;align-items:center;gap:30px;font-size:14.5px;color:var(--ink2);font-weight:500}
  .nav-links a:hover{color:var(--ink)}
  .nav-cta{font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:0.4px;background:var(--forest);color:var(--cream);padding:10px 18px;border-radius:8px;text-transform:uppercase;white-space:nowrap}

  /* HERO */
  .hero{background:var(--forest);color:var(--cream-ink);position:relative;overflow:hidden}
  .hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 80% -10%, rgba(201,162,74,0.14), transparent 55%);pointer-events:none}
  .hero-in{max-width:var(--maxw);margin:0 auto;padding:92px 40px 96px;position:relative;z-index:2;display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center}
  .hero .eyebrow{color:var(--brass-bright);margin-bottom:24px}
  .hero h1{font-family:var(--serif);font-weight:500;font-size:60px;line-height:1.07;letter-spacing:-1.3px;color:#fff}
  .hero h1 em{font-style:italic;color:var(--brass-bright)}
  .hero p.lede{margin-top:26px;font-size:18px;line-height:1.6;color:var(--cream-ink2);max-width:46ch}
  .hero-art{display:flex;justify-content:center;position:relative}
  .hero-art::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,74,0.16),transparent 68%);top:50%;left:50%;transform:translate(-50%,-50%)}
  .hero-art .phone{transform:rotate(2.5deg)}
  .hero-actions{margin-top:40px;display:flex;align-items:center;gap:18px}
  .btn-brass{background:var(--brass-bright);color:var(--forest);font-weight:600;font-size:15px;padding:15px 26px;border-radius:10px;font-family:var(--sans);display:inline-flex;align-items:center;white-space:nowrap}
  .btn-ghost{border:1px solid var(--hair-d);color:var(--cream-ink);font-weight:500;font-size:15px;padding:15px 24px;border-radius:10px;display:inline-flex;align-items:center;white-space:nowrap}
  .btn-ghost:hover{border-color:var(--brass-bright);color:#fff}
  .hero-meta{margin-top:64px;display:flex;gap:46px;border-top:1px solid var(--hair-d);padding-top:30px}
  .hero-meta .stat .n{font-family:var(--serif);font-size:34px;font-weight:600;color:#fff;letter-spacing:-0.5px}
  .hero-meta .stat .l{font-family:var(--mono);font-size:11.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--cream-ink3);margin-top:6px}

  /* SECTION SCAFFOLD */
  section{padding:104px 0}
  .sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:54px}
  .sec-head .eyebrow{color:var(--brass)}
  .sec-head h2{font-family:var(--serif);font-weight:500;font-size:46px;line-height:1.08;letter-spacing:-1px;margin-top:16px;max-width:18ch}
  .sec-head p{color:var(--ink2);font-size:16px;max-width:40ch;line-height:1.6}

  /* APPS */
  .apps{background:var(--cream2)}
  .app-row{display:grid;grid-template-columns:1fr 300px;gap:56px;align-items:center;padding:48px 0;border-top:1px solid var(--hair)}
  .app-row:last-child{border-bottom:1px solid var(--hair)}
  .app-row.rev{grid-template-columns:300px 1fr}
  .app-row.rev .app-copy{order:2}
  .app-badge{font-family:var(--mono);font-size:11.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--brass);font-weight:600}
  .app-copy h3{font-family:var(--serif);font-weight:600;font-size:38px;letter-spacing:-0.6px;margin:14px 0 8px}
  .app-copy .tag{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--leaf);margin-bottom:18px}
  .app-copy p{color:var(--ink2);font-size:16px;line-height:1.65;max-width:46ch}
  .app-feats{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
  .chip{font-family:var(--mono);font-size:12px;letter-spacing:0.4px;color:var(--ink2);background:var(--card);border:1px solid var(--hair);padding:8px 13px;border-radius:999px}
  .app-link{display:inline-flex;align-items:center;gap:8px;margin-top:28px;font-weight:600;font-size:14.5px;color:var(--forest);border-bottom:2px solid var(--brass-bright);padding-bottom:3px;white-space:nowrap}

  /* PHONE MOCKUPS */
  .phone-stage{display:flex;justify-content:center}
  .phone{width:268px;height:548px;background:#0c1410;border-radius:42px;padding:11px;box-shadow:0 30px 70px -28px rgba(20,36,26,0.6),0 0 0 1px rgba(0,0,0,0.3);position:relative}
  .phone .notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:108px;height:24px;background:#0c1410;border-radius:0 0 16px 16px;z-index:5}
  .screen{width:100%;height:100%;border-radius:32px;overflow:hidden;position:relative}

  /* GolfTracker screen (Clubhouse) */
  .gt{height:100%;background:#F4EFDF;color:#1A211C;display:flex;flex-direction:column;padding-top:30px;font-family:var(--sans)}
  .gt-top{padding:10px 16px 8px;display:flex;align-items:center;justify-content:space-between}
  .gt-top .t{font-family:var(--serif);font-size:18px;font-weight:600;font-variant:small-caps;letter-spacing:0.3px}
  .gt-seg{background:#FFFAEC;border:1px solid #E0D8BD;border-radius:999px;padding:3px;display:flex;gap:2px}
  .gt-seg span{font-size:9.5px;font-weight:600;padding:4px 8px;border-radius:999px;color:#5A5A47}
  .gt-seg span.on{background:#9A7615;color:#fff}
  .gt-card{margin:6px 14px 0;background:#FFFAEC;border:1px solid #E0D8BD;border-radius:14px;padding:14px}
  .gt-card .row1{display:flex;align-items:flex-start;justify-content:space-between}
  .gt-card .lbl{font-family:var(--mono);font-size:8.5px;letter-spacing:1.4px;color:#8E886F;font-weight:700;text-transform:uppercase}
  .gt-card .crs{font-family:var(--serif);font-size:15px;font-weight:600;margin-top:3px;white-space:nowrap}
  .gt-card .score{font-family:var(--mono);font-size:34px;font-weight:700;line-height:0.9;letter-spacing:-1px}
  .gt-card .par{font-family:var(--mono);font-size:10px;color:#3D7A3F;font-weight:700;letter-spacing:0.4px;text-align:right;margin-top:3px;white-space:nowrap}
  .gt-holes{margin-top:12px;display:grid;grid-template-columns:repeat(9,1fr);gap:3px}
  .gt-holes .h{aspect-ratio:1;background:#FBF5DF;border:1px solid #E0D8BD;border-radius:5px;display:grid;place-items:center;font-family:var(--mono);font-size:10px;font-weight:700}
  .gt-holes .h.b{color:#3D7A3F}.gt-holes .h.r{color:#A12626}
  .gt-foot9{display:flex;justify-content:space-between;margin-top:6px;font-family:var(--mono);font-size:8.5px;letter-spacing:0.6px;color:#8E886F;white-space:nowrap}
  .gt-foot9 b{color:#1A211C}
  .gt-list{padding:12px 14px 0;display:flex;flex-direction:column;gap:7px;flex:1}
  .gt-li{display:flex;align-items:center;gap:9px;background:#FFFAEC;border:1px solid #E0D8BD;border-radius:10px;padding:8px 10px}
  .gt-li .ab{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;font-family:var(--mono);font-size:9px;font-weight:700}
  .gt-li .nm{flex:1;font-size:12px;font-weight:600}
  .gt-li .nm small{display:block;font-family:var(--mono);font-size:8.5px;color:#8E886F;font-weight:500;margin-top:2px}
  .gt-li .st{font-family:var(--mono);font-size:16px;font-weight:700;letter-spacing:-0.4px}
  .gt-cta{margin:12px 14px 14px;height:42px;border-radius:11px;background:#9A7615;color:#fff;display:grid;place-items:center;font-family:var(--serif);font-variant:small-caps;font-weight:600;font-size:14px}

  /* TeamStreamer screen (navy hybrid) */
  .ts{height:100%;background:#0F1A28;color:#EFF3F8;display:flex;flex-direction:column;padding-top:30px;font-family:var(--sans)}
  .ts-top{padding:8px 18px 2px;display:flex;align-items:center;justify-content:space-between}
  .ts-top .d{font-family:var(--mono);font-size:8.5px;letter-spacing:1.4px;color:#5E6F86;font-weight:600}
  .ts-top .ic{width:28px;height:28px;border-radius:999px;background:#162638;border:1px solid #243A55}
  .ts-wm{padding:2px 18px 10px;font-size:25px;font-weight:800;letter-spacing:-0.7px;font-family:var(--sans)}
  .ts-wm b{color:#3FA0CF;font-weight:800}
  .ts-sec{padding:8px 18px 4px;display:flex;justify-content:space-between;align-items:baseline}
  .ts-sec .l{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;color:#5E6F86;font-weight:700}
  .ts-sec .s{font-family:var(--mono);font-size:8px;letter-spacing:1px;color:#5E6F86;display:flex;gap:11px}
  .ts-list{padding:0 14px;display:flex;flex-direction:column;gap:7px;flex:1}
  .ts-li{background:#162638;border:1px solid #243A55;border-radius:10px;padding:9px 11px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
  .ts-li .nm{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700}
  .ts-li .dot{width:6px;height:6px;border-radius:2px}
  .ts-li .meta{margin-top:4px;margin-left:13px;font-family:var(--mono);font-size:8.5px;color:#A0AFC4;letter-spacing:0.3px}
  .ts-li .sets{display:flex;align-items:center;gap:7px}
  .ts-li .setcol{display:flex;flex-direction:column;align-items:center;font-family:var(--mono);font-size:10px;font-weight:700;line-height:1.05}
  .ts-li .setcol .lo{color:#5E6F86}
  .ts-cta{margin:12px 14px 14px;height:44px;border-radius:9px;background:#1B6B93;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}

  /* APPROACH */
  .approach{background:var(--forest);color:var(--cream-ink)}
  .approach .eyebrow{color:var(--brass-bright)}
  .approach h2{color:#fff}
  .appr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair-d);border:1px solid var(--hair-d);border-radius:16px;overflow:hidden}
  .appr-cell{background:var(--forest2);padding:38px 32px}
  .appr-cell .num{font-family:var(--mono);font-size:12px;color:var(--brass-bright);letter-spacing:1.4px;font-weight:600}
  .appr-cell h4{font-family:var(--serif);font-size:25px;font-weight:600;margin:18px 0 12px;letter-spacing:-0.3px;color:#fff}
  .appr-cell p{color:var(--cream-ink2);font-size:15px;line-height:1.62}

  /* CONTACT */
  .contact{background:var(--cream2)}
  .contact-card{background:var(--card);border:1px solid var(--hair);border-radius:22px;padding:64px 60px;display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center;box-shadow:0 30px 60px -40px rgba(20,36,26,0.3)}
  .contact-card .eyebrow{color:var(--brass)}
  .contact-card h2{font-family:var(--serif);font-weight:500;font-size:42px;letter-spacing:-0.8px;margin:16px 0 18px;line-height:1.08}
  .contact-card p{color:var(--ink2);font-size:16px;line-height:1.62;max-width:42ch}
  .form{display:flex;flex-direction:column;gap:14px}
  .form label{font-family:var(--mono);font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink3);font-weight:600}
  .form input,.form textarea{font-family:var(--sans);font-size:15px;background:var(--cream2);border:1px solid var(--hair);border-radius:10px;padding:13px 15px;color:var(--ink);width:100%}
  .form input:focus,.form textarea:focus{outline:none;border-color:var(--brass)}
  .form .field{display:flex;flex-direction:column;gap:7px}
  .form button{margin-top:6px;background:var(--forest);color:var(--cream);font-family:var(--sans);font-weight:600;font-size:15px;padding:15px;border:none;border-radius:10px;cursor:pointer}

  /* FOOTER */
  footer{background:var(--forest);color:var(--cream-ink2);padding:70px 0 40px}
  .foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid var(--hair-d)}
  .foot-brand .logo{color:#fff}
  .foot-brand p{margin-top:18px;font-size:14.5px;line-height:1.6;max-width:34ch;color:var(--cream-ink3)}
  .foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--cream-ink3);margin-bottom:18px;font-weight:600}
  .foot-col a{display:block;font-size:14.5px;color:var(--cream-ink2);padding:6px 0}
  .foot-col a:hover{color:var(--brass-bright)}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-family:var(--mono);font-size:12px;letter-spacing:0.4px;color:var(--cream-ink3)}
  .foot-bot a{color:var(--cream-ink3)}.foot-bot a:hover{color:var(--brass-bright)}

  /* ===== FAIRWAY · LIGHT OVERRIDES ===== */
  body{background:var(--cream)}
  /* LIGHT HERO — editorial, airy */
  .hero{background:linear-gradient(180deg,#FBF5E6 0%,var(--cream2) 100%);color:var(--ink)}
  .hero::after{background:radial-gradient(115% 95% at 86% 2%, rgba(154,118,21,0.10), transparent 56%)}
  .hero-in{padding:108px 40px 110px}
  .hero .eyebrow{color:var(--brass)}
  .hero h1{color:var(--ink)}
  .hero h1 em{color:var(--brass)}
  .hero p.lede{color:var(--ink2)}
  .hero-meta{border-top:1px solid var(--hair)}
  .hero-meta .stat .n{color:var(--ink)}
  .hero-meta .stat .l{color:var(--ink3)}
  .btn-brass{box-shadow:0 14px 28px -14px rgba(154,118,21,0.55)}
  .btn-ghost{border:1px solid var(--hair);color:var(--ink)}
  .btn-ghost:hover{border-color:var(--brass);color:var(--brass)}
  .hero-art{display:flex;align-items:center;justify-content:center;position:relative;background:radial-gradient(130% 120% at 50% -8%, #213A2B 0%, #15271B 62%, #11211700 100%),#142318;border:1px solid #2A4B36;border-radius:32px;padding:50px 24px;box-shadow:0 50px 110px -46px rgba(13,24,17,0.62), inset 0 1px 0 rgba(255,255,255,0.05);overflow:hidden}
  .hero-art::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,74,0.22),transparent 64%);top:40%;left:50%;transform:translate(-50%,-50%)}
  .hero-art .phone{transform:rotate(2deg);position:relative;z-index:1;box-shadow:0 40px 80px -30px rgba(0,0,0,0.55),0 0 0 1px rgba(0,0,0,0.3)}
  /* LIGHT APPROACH — cream cards, brass numerals */
  .approach{background:var(--cream);color:var(--ink);border-top:1px solid var(--hair)}
  .approach .eyebrow{color:var(--brass)}
  .approach h2{color:var(--ink)}
  .approach .sec-head p{color:var(--ink2)}
  .appr-grid{background:var(--hair);border:1px solid var(--hair);border-radius:18px}
  .appr-cell{background:var(--cream2)}
  .appr-cell .num{color:var(--brass)}
  .appr-cell h4{color:var(--ink)}
  .appr-cell p{color:var(--ink2)}
  /* softer cards */
  .contact-card{border-radius:24px;box-shadow:0 44px 80px -50px rgba(20,36,26,0.32)}
  .app-feats .chip{background:var(--cream2)}
  /* app-themed stages echo each app's palette */
  .app-row .phone-stage{border-radius:28px;padding:32px 12px}
  .app-row:not(.rev) .phone-stage{background:radial-gradient(circle at 50% 36%, rgba(201,162,74,0.18), transparent 60%), radial-gradient(130% 120% at 50% -8%, #213A2B 0%, #14241A 64%);border:1px solid #2A4B36;box-shadow:0 40px 80px -44px rgba(13,24,17,0.55)}
  .app-row.rev .phone-stage{background:radial-gradient(circle at 50% 36%, rgba(98,183,226,0.22), transparent 60%), radial-gradient(130% 120% at 50% -8%, #1C3350 0%, #0F1E30 64%);border:1px solid #294B6E;box-shadow:0 40px 80px -44px rgba(6,16,28,0.55)}
  @media(max-width:980px){
    .hero-in{grid-template-columns:1fr}
    .hero-art{display:none}
    .hero h1{font-size:52px}
    .app-row,.app-row.rev{grid-template-columns:1fr}
    .app-row.rev .app-copy{order:0}
    .appr-grid{grid-template-columns:1fr}
    .contact-card{grid-template-columns:1fr;padding:44px 32px}
    .foot-top{grid-template-columns:1fr 1fr}
  }

/* TeamStreamer — explicit section backgrounds (not relying on CSS var inheritance) */
body.page-teamstreamer .ts-frows,
body.page-template-page-teamstreamer .ts-frows {
  background: #0F1A28;
}
body.page-teamstreamer .gallery-sec,
body.page-template-page-teamstreamer .gallery-sec {
  background: #0F1A28;
}

/* TeamStreamer — nav text colours */
body.page-teamstreamer .logo,
body.page-template-page-teamstreamer .logo {
  color: #EFF3F8;
}
body.page-teamstreamer .nav-links a,
body.page-template-page-teamstreamer .nav-links a {
  color: #A6B7CD;
}
body.page-teamstreamer .nav-links a:hover,
body.page-template-page-teamstreamer .nav-links a:hover {
  color: #EFF3F8;
}
body.page-teamstreamer .nav-links a.active,
body.page-template-page-teamstreamer .nav-links a.active {
  color: #EFF3F8;
}
body.page-teamstreamer .nav-toggle span,
body.page-template-page-teamstreamer .nav-toggle span {
  background: #EFF3F8;
}

/* Mobile nav — un-hide links when menu is open (overrides site.css display:none) */
@media(max-width:860px){
  .nav-links.open a {
    display: block !important;
  }
  .nav-links.open a.nav-cta {
    display: inline-flex !important;
    margin-top: 8px;
  }
}