
/* ════════════════════════════════════════════
   FORE!CAST — Complete Design System v3
   Refined Nordic · Golf · Weather
════════════════════════════════════════════ */

:root{
  --ink:#0a1a10; --ink-mid:#1c3224; --ink-sub:#3f5a48; --ink-muted:#7a9a86; --ink-ghost:#b5cfc0;
  --sage:#2d6e4e; --sage-mid:#3a8862; --sage-light:#54a87c; --sage-bright:#6dba92;
  --cream:#f3f7f4; --white:#ffffff; --surface-2:#edf4ef; --surface-3:#e3ede6;
  --border:#d9e8de; --border-soft:#eaf2ec;
  --gold:#b87020; --gold-bg:rgba(184,112,32,.08);
  --r:16px; --r-sm:10px; --r-xs:6px;
  --shadow:0 1px 2px rgba(10,26,16,.04),0 3px 12px rgba(10,26,16,.07);
  --shadow-md:0 2px 6px rgba(10,26,16,.07),0 8px 24px rgba(10,26,16,.09);
  --shadow-card:0 1px 3px rgba(10,26,16,.04),0 4px 20px rgba(10,26,16,.06);
  --font-display:'DM Serif Display',serif;
  --font-body:'DM Sans',sans-serif;
  --font-mono:'DM Mono',monospace;
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{background:var(--cream);}
body{font-family:var(--font-body);background:var(--cream);color:var(--ink);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;}

/* ── ANIMATIONS ──────────────────────────── */
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.3;transform:scale(1.6);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeOut{from{opacity:1;}to{opacity:0;}}
@keyframes rise{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
.anim{animation:fadeUp .32s cubic-bezier(.22,1,.36,1) both;}

/* ── HEADER ──────────────────────────────── */
header{position:sticky;top:0;z-index:200;background:var(--ink);padding-top:env(safe-area-inset-top,0);border-bottom:1px solid rgba(255,255,255,.04);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 10px;}
.logo{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0;}
.logo-box{width:30px;height:30px;background:linear-gradient(135deg,var(--sage-bright),var(--sage-light));border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;color:var(--ink);box-shadow:0 2px 8px rgba(109,186,146,.3);}
.logo-title{font-family:var(--font-display);font-size:17px;color:#fff;letter-spacing:.3px;}
.logo-sub{font-size:9px;color:rgba(255,255,255,.25);letter-spacing:.8px;margin-top:1px;font-weight:300;}
.menu-btn{width:34px;height:34px;border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:rgba(255,255,255,.04);cursor:pointer;transition:border-color .2s,background .2s;flex-shrink:0;}
.menu-btn:hover{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.07);}
.menu-btn span{display:block;width:14px;height:1.5px;background:rgba(255,255,255,.55);border-radius:1px;}

/* ── SEARCH ──────────────────────────────── */
.search-wrap{background:var(--ink);padding:0 14px 14px;position:relative;}
.search-field{display:flex;align-items:center;gap:0;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.1);border-radius:14px;padding:0 5px 0 14px;transition:border-color .18s,background .18s,box-shadow .18s;}
.search-field:focus-within{border-color:var(--sage-bright);background:rgba(109,186,146,.08);box-shadow:0 0 0 3px rgba(109,186,146,.12);}
.search-field svg{flex-shrink:0;opacity:.4;}
.search-field input{flex:1;background:none;border:none;outline:none;font-family:var(--font-body);font-size:15px;font-weight:300;color:#fff;padding:12px 10px;letter-spacing:.1px;}
.search-field input::placeholder{color:rgba(255,255,255,.25);}
.search-btn{background:linear-gradient(135deg,var(--sage-mid),var(--sage));color:#fff;border:none;border-radius:10px;padding:8px 16px;font-family:var(--font-body);font-size:12px;font-weight:500;cursor:pointer;letter-spacing:.3px;transition:opacity .15s,transform .1s;flex-shrink:0;box-shadow:0 2px 8px rgba(45,110,78,.3);}
.search-btn:active{transform:scale(.94);}
.search-btn:hover{opacity:.88;}

/* Autocomplete */
.ac-list{position:absolute;left:14px;right:14px;top:calc(100% - 2px);background:var(--ink-mid);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);box-shadow:0 16px 48px rgba(0,0,0,.55);z-index:100;overflow:hidden;}
.ac-item{padding:11px 14px;font-size:13px;color:rgba(255,255,255,.62);cursor:pointer;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-weight:300;transition:background .1s;}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover,.ac-item.focused{background:rgba(255,255,255,.07);color:rgba(255,255,255,.9);}
.ac-dot{width:4px;height:4px;border-radius:50%;background:var(--sage-bright);flex-shrink:0;opacity:.7;}
.ac-item b{color:var(--sage-bright);font-weight:500;}

/* ── MENU ──────────────────────────────────*/
.menu-overlay{position:fixed;inset:0;z-index:300;display:none;}
.menu-overlay.open{display:block;}
.menu-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);}
.menu-panel{position:absolute;top:0;right:0;bottom:0;width:min(300px,85vw);background:var(--cream);box-shadow:-12px 0 40px rgba(0,0,0,.18);display:flex;flex-direction:column;animation:slideIn .22s cubic-bezier(.22,1,.36,1);}
@keyframes slideIn{from{transform:translateX(100%);}to{transform:translateX(0);}}
.menu-head{background:var(--ink);padding:env(safe-area-inset-top,14px) 18px 16px;display:flex;align-items:center;justify-content:space-between;}
.menu-head-logo{display:flex;align-items:center;gap:10px;}
.menu-head-box{width:28px;height:28px;background:linear-gradient(135deg,var(--sage-bright),var(--sage-light));border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:12px;color:var(--ink);}
.menu-head-title{color:#fff;font-family:var(--font-display);font-size:17px;font-weight:400;letter-spacing:.3px;}
.menu-head-ver{font-size:9px;color:rgba(255,255,255,.28);letter-spacing:.8px;margin-top:1px;font-weight:300;}
.menu-close{width:30px;height:30px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:none;color:rgba(255,255,255,.5);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.menu-close:hover{border-color:rgba(255,255,255,.3);color:#fff;}
.menu-body{flex:1;overflow-y:auto;padding:8px 0 20px;}
.menu-group{margin:0 12px 4px;}
.menu-group-label{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--ink-ghost);padding:12px 6px 5px;}
.menu-group-box{background:var(--white);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow);}
.menu-item{padding:11px 14px;cursor:pointer;transition:background .1s;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--border-soft);}
.menu-item:last-child{border-bottom:none;}
.menu-item:hover{background:var(--surface-2);}
.menu-item-icon{width:28px;height:28px;border-radius:6px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.menu-item-icon svg{width:13px;height:13px;stroke:var(--ink-sub);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.menu-item-text{flex:1;}
.menu-item-title{font-size:13px;font-weight:500;color:var(--ink);}
.menu-item-sub{font-size:11px;color:var(--ink-muted);margin-top:1px;font-weight:300;}
.menu-item-arrow{color:var(--ink-ghost);display:flex;align-items:center;}
.menu-item-arrow svg{width:11px;height:11px;stroke:var(--ink-muted);fill:none;stroke-width:1.5;}
.menu-section{display:none;background:var(--surface-2);border-top:1px solid var(--border-soft);padding:14px;}
.menu-section.open{display:block;}
.menu-section h3{font-size:9px;font-weight:600;color:var(--sage);margin-bottom:8px;letter-spacing:1.5px;text-transform:uppercase;}
.menu-section p,.menu-section li{font-size:12px;color:var(--ink-sub);line-height:1.75;margin-bottom:5px;font-weight:300;}
.menu-section ul{padding-left:14px;}
.menu-section .install-steps{counter-reset:step;}
.menu-section .install-steps li{counter-increment:step;list-style:none;padding-left:0;margin-bottom:8px;display:flex;gap:8px;}
.menu-section .install-steps li::before{content:counter(step);width:18px;height:18px;background:var(--sage);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0;}
.menu-fav-list{display:flex;flex-direction:column;}
.menu-fav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border-soft);}
.menu-fav-item:last-child{border-bottom:none;}
.menu-fav-item:hover{background:var(--surface-2);}
.menu-fav-star{width:16px;height:16px;flex-shrink:0;}
.menu-fav-star svg{width:14px;height:14px;fill:#c8920a;stroke:none;}
.menu-fav-name{flex:1;font-size:13px;font-weight:400;color:var(--ink);}
.menu-fav-empty{padding:14px;font-size:12px;color:var(--ink-muted);text-align:center;font-weight:300;font-style:italic;}
.menu-fav-del{padding:3px 8px;font-size:10px;font-weight:500;color:var(--ink-muted);background:transparent;border:1px solid var(--border);border-radius:4px;cursor:pointer;letter-spacing:.3px;transition:border-color .15s,color .15s;}
.menu-fav-del:hover{border-color:#c0392b;color:#c0392b;}

/* ── MAIN ──────────────────────────────────*/
main{max-width:460px;margin:0 auto;padding:14px 13px 68px;display:flex;flex-direction:column;gap:10px;}

/* ── LOADING ────────────────────────────── */
.loading{display:flex;flex-direction:column;align-items:center;padding:80px 20px;gap:14px;color:var(--ink-muted);}
.loader{width:26px;height:26px;border:2px solid var(--border);border-top-color:var(--sage-bright);border-radius:50%;animation:spin .75s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading p{font-size:13px;font-weight:300;letter-spacing:.3px;}

/* ── WARNING BAR ──────────────────────────*/
.wx-warning{padding:8px 16px;font-size:11px;display:flex;align-items:center;gap:7px;font-weight:400;letter-spacing:.2px;border-bottom:1px solid transparent;}
.wx-warning.orange{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.2);color:#92600a;}
.wx-warning.red{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.2);color:#b91c1c;}
.wx-warning.blue{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.2);color:#1e40af;}

/* ── STATS ROW ────────────────────────────*/
.stats-row{display:flex;gap:8px;overflow-x:auto;padding:2px 0 4px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.stats-row::-webkit-scrollbar{display:none;}
.stat-card{background:var(--white);border:1.5px solid var(--border);border-radius:13px;padding:12px 16px;display:flex;flex-direction:column;flex-shrink:0;min-width:92px;box-shadow:var(--shadow-card);}
.stat-card-num{font-family:var(--font-display);font-size:21px;color:var(--sage);line-height:1;margin-bottom:3px;}
.stat-card-label{font-size:9px;color:var(--ink-ghost);font-weight:500;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;}

/* ── SECTION LABEL ────────────────────────*/
.section-label{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--ink-muted);padding:0 2px;}

/* ── NEARBY ───────────────────────────────*/
.nearby-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:13px 15px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;box-shadow:var(--shadow-card);}
.nearby-card:hover{border-color:var(--sage-bright);box-shadow:var(--shadow-md);transform:translateY(-1px);}
.nearby-card.active{border-color:var(--sage-light);background:rgba(109,186,146,.06);}
.nearby-num{width:28px;height:28px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--ink-sub);flex-shrink:0;}
.nearby-card.active .nearby-num{background:var(--sage);color:#fff;}
.nearby-info{flex:1;min-width:0;}
.nearby-name{font-size:14px;font-weight:400;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nearby-dist{font-size:11px;color:var(--ink-muted);margin-top:2px;font-weight:300;}
.nearby-cta{font-size:10px;font-weight:600;color:var(--sage);letter-spacing:.8px;text-transform:uppercase;flex-shrink:0;}
.nearby-card.active .nearby-cta{color:var(--sage-mid);}

/* ── GPS BUTTONS ──────────────────────────*/
.gps-btn{background:var(--ink);color:#fff;border:none;border-radius:var(--r);padding:14px 16px;font-family:var(--font-body);font-size:13px;font-weight:400;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;letter-spacing:.3px;transition:opacity .15s;box-shadow:0 4px 16px rgba(10,26,16,.18);}
.gps-btn:hover{opacity:.84;}
.gps-pulse{width:7px;height:7px;border-radius:50%;background:var(--sage-bright);animation:pulse 1.5s infinite;}
.back-btn{background:var(--white);border:1.5px solid var(--border);color:var(--ink-sub);border-radius:var(--r);padding:12px 16px;font-family:var(--font-body);font-size:13px;font-weight:400;cursor:pointer;width:100%;letter-spacing:.2px;transition:border-color .15s,color .15s;box-shadow:var(--shadow);}
.back-btn:hover{border-color:var(--sage-bright);color:var(--sage);}

/* ── GPS HERO CARD ────────────────────────*/
.gps-hero{background:var(--white);border:1.5px solid var(--border);border-radius:20px;padding:24px 18px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;box-shadow:var(--shadow-md);}
.gps-hero-icon{position:relative;width:54px;height:54px;display:flex;align-items:center;justify-content:center;background:rgba(109,186,146,.1);border:1px solid rgba(109,186,146,.18);border-radius:50%;}
.gps-hero-text{}
.gps-hero-title{font-family:var(--font-display);font-size:19px;color:var(--ink);margin-bottom:3px;}
.gps-hero-sub{font-size:12px;color:var(--ink-muted);font-weight:300;line-height:1.6;max-width:240px;margin:0 auto;}
.gps-hero-btn{background:linear-gradient(135deg,var(--sage-mid),var(--sage));color:#fff;border:none;border-radius:var(--r-sm);padding:12px 30px;font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;letter-spacing:.2px;transition:opacity .15s,transform .12s;box-shadow:0 4px 14px rgba(45,110,78,.28);}
.gps-hero-btn:hover{opacity:.88;}
.gps-hero-btn:active{transform:scale(.97);}

/* ── HERO ─────────────────────────────────*/
.hero{background:var(--ink);border-radius:20px;position:relative;overflow:hidden;box-shadow:0 6px 28px rgba(0,0,0,.26);}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 75% 55% at 88% -5%,rgba(109,186,146,.16),transparent 55%),radial-gradient(ellipse 55% 75% at -5% 105%,rgba(20,46,30,.65),transparent 60%);pointer-events:none;z-index:0;}
.hero>*{position:relative;z-index:1;}
.hero-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 0;}
.hero-back{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:5px 12px;font-family:var(--font-body);font-size:11px;font-weight:400;color:rgba(255,255,255,.5);cursor:pointer;letter-spacing:.3px;display:flex;align-items:center;gap:5px;transition:all .15s;}
.hero-back:hover{border-color:rgba(255,255,255,.22);color:rgba(255,255,255,.8);}
.hero-back svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:1.5;}
.hero-fav{width:34px;height:34px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;}
.hero-fav svg{width:13px;height:13px;stroke:rgba(255,255,255,.5);fill:none;stroke-width:1.5;}
.hero-fav.saved{background:rgba(212,160,23,.18);border-color:rgba(212,160,23,.35);}
.hero-fav.saved svg{fill:#d4a017;stroke:#d4a017;}
.hero-fav:active{transform:scale(.88);}
.hero-loc{font-size:9px;color:rgba(255,255,255,.28);letter-spacing:1.8px;text-transform:uppercase;font-weight:400;padding:14px 16px 0;}
.hero-club{font-family:var(--font-display);font-size:23px;line-height:1.15;color:#fff;padding:4px 16px 0;letter-spacing:.2px;}
.hero-main-row{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 16px 0;gap:10px;}
.hero-temp-row{display:flex;align-items:flex-end;gap:2px;}
.hero-temp{font-family:var(--font-display);font-size:78px;font-weight:400;line-height:.85;color:#fff;letter-spacing:-3px;}
.hero-unit{font-size:22px;color:rgba(255,255,255,.28);font-weight:300;margin-bottom:10px;}
.hero-desc{font-size:14px;font-weight:400;color:rgba(255,255,255,.78);margin-top:7px;letter-spacing:.1px;}
.hero-feels{font-size:11px;color:rgba(255,255,255,.3);font-weight:300;margin-top:3px;}
.hero-idx-pill{border-radius:14px;padding:12px 14px;text-align:center;min-width:70px;flex-shrink:0;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.07);}
.hero-idx-num{font-family:var(--font-display);font-size:32px;line-height:1;}
.hero-idx-label{font-size:8px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;margin-top:4px;opacity:.6;}
.hero-divider{height:1px;background:rgba(255,255,255,.06);margin:14px 16px 0;}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);padding:12px 0 16px;}
.hstat{text-align:center;padding:2px 4px;}
.hstat+.hstat{border-left:1px solid rgba(255,255,255,.06);}
.hstat-val{font-family:var(--font-mono);font-size:13px;font-weight:400;color:rgba(255,255,255,.85);display:block;letter-spacing:.2px;}
.hstat-label{font-size:9px;color:rgba(255,255,255,.27);margin-top:3px;letter-spacing:.8px;text-transform:uppercase;}
.hero-meta-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:0 16px 14px;font-size:10px;color:rgba(255,255,255,.24);font-weight:300;letter-spacing:.3px;}
.hero-meta-row strong{color:rgba(255,255,255,.48);font-weight:400;}
.hero-meta-dot{width:2px;height:2px;border-radius:50%;background:rgba(255,255,255,.15);flex-shrink:0;}

/* ── CARD BASE ────────────────────────────*/
.card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 16px 18px;box-shadow:var(--shadow-card);}
.card.mini{padding:14px 14px 15px;}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.card-title{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:16px;font-weight:400;color:var(--ink);letter-spacing:.2px;}
.card-title-line{width:3px;height:16px;border-radius:2px;background:linear-gradient(to bottom,var(--sage-bright),var(--sage));flex-shrink:0;}

/* ── ACTION ROW (play banner + share) ────*/
.action-row{display:flex;gap:8px;align-items:stretch;}
.play-banner{flex:1;display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:var(--r);border:1.5px solid transparent;box-shadow:var(--shadow-card);}
.play-banner.green{background:rgba(45,110,78,.09);border-color:rgba(45,110,78,.18);}
.play-banner.yellow{background:rgba(184,112,32,.08);border-color:rgba(184,112,32,.18);}
.play-banner.red{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.18);}
.play-banner-icon{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.play-banner-title{font-size:13px;font-weight:500;color:var(--ink);line-height:1.3;}
.play-banner-sub{font-size:11px;color:var(--ink-muted);margin-top:2px;font-weight:300;line-height:1.4;}
.share-btn{width:48px;border:1.5px solid var(--border);border-radius:var(--r);background:var(--white);color:var(--ink-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s;flex-shrink:0;box-shadow:var(--shadow);}
.share-btn:hover{border-color:var(--sage-bright);color:var(--sage);}

/* ── GOLF INDEX ───────────────────────────*/
.idx-layout{display:flex;align-items:center;gap:16px;}
.idx-ring{position:relative;width:80px;height:80px;flex-shrink:0;}
.idx-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.idx-num{font-family:var(--font-display);font-size:22px;line-height:1;}
.idx-denom{font-size:9px;color:var(--ink-muted);font-weight:500;margin-top:1px;}
.idx-right{flex:1;min-width:0;}
.idx-verdict{font-size:13px;font-weight:500;margin-bottom:10px;letter-spacing:.1px;}
.idx-bars{display:flex;flex-direction:column;gap:6px;}
.ibar{}
.ibar-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-muted);margin-bottom:3px;font-weight:300;}
.track{height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden;}
.fill{height:100%;background:linear-gradient(to right,var(--sage-light),var(--sage-bright));border-radius:2px;transition:width .6s ease;}

/* ── BANFÖRHÅLLANDEN ──────────────────────*/
.cond-top{margin-bottom:12px;}
.cond-title{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:4px;}
.cond-desc{font-size:12px;color:var(--ink-sub);line-height:1.6;font-weight:300;}
.cond-history{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}
.cond-history-item{background:var(--surface-2);border-radius:var(--r-sm);padding:10px 12px;}
.cond-history-label{font-size:9px;font-weight:600;color:var(--ink-muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:3px;}
.cond-history-val{font-size:12px;font-weight:400;color:var(--ink);}
.moisture{margin-top:4px;}
.moisture-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-muted);margin-bottom:5px;font-weight:300;}
.mtrack{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden;}
.mfill{height:100%;background:linear-gradient(to right,var(--sage-light),#3b82f6);border-radius:3px;transition:width .6s ease;}

/* ── WIND + RAIN MINI CARDS ───────────────*/
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.mini-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted);margin-bottom:8px;display:flex;align-items:center;gap:5px;}
.mini-dot{width:5px;height:5px;border-radius:50%;background:var(--sage-bright);flex-shrink:0;}
.mini-num{font-family:var(--font-display);font-size:32px;color:var(--ink);line-height:1;}
.mini-unit{font-size:13px;color:var(--ink-muted);font-weight:300;}
.mini-sub{font-size:11px;color:var(--ink-sub);margin-top:3px;margin-bottom:10px;font-weight:300;}
.mini-extra{font-size:11px;color:var(--ink-muted);font-weight:300;line-height:1.7;}

/* Compass */
.compass{position:relative;width:56px;height:56px;border:1.5px solid var(--border);border-radius:50%;margin:10px 0 4px;background:var(--surface-2);}
.compass-n{position:absolute;top:2px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:700;color:var(--ink-sub);}
.compass-s{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:700;color:var(--ink-ghost);}
.compass-needle{position:absolute;top:50%;left:50%;width:2px;height:22px;background:linear-gradient(to bottom,var(--sage),var(--ink-ghost));border-radius:1px;transform-origin:bottom center;margin-left:-1px;margin-top:-22px;}
.compass-dir{font-size:10px;color:var(--ink-sub);font-weight:400;letter-spacing:.5px;}

/* Rain bar */
.rain-bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-top:10px;}
.rain-fill{height:100%;border-radius:3px;background:linear-gradient(to right,#60a5fa,#2563eb);transition:width .6s ease;}

/* ── SUN / DAGSLJUS ───────────────────────*/
.sun-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.sun-main{}
.sun-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted);margin-bottom:4px;}
.sun-big{font-family:var(--font-display);font-size:30px;color:var(--ink);line-height:1;}
.sun-sub{font-size:11px;color:var(--ink-muted);margin-top:4px;font-weight:300;line-height:1.5;}
.sun-times{display:flex;flex-direction:column;gap:7px;}
.sun-time-item{display:flex;align-items:center;gap:7px;}
.sun-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.sun-dot.rise{background:#f59e0b;}
.sun-dot.set{background:#6366f1;}
.sun-time-val{font-family:var(--font-mono);font-size:12px;font-weight:400;color:var(--ink);}

/* Day bar (sun arc) */
.day-bar-wrap{margin:4px 0 6px;}
.day-bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden;position:relative;}
.day-fill{height:100%;background:linear-gradient(to right,#f59e0b,#f97316,#6366f1);border-radius:3px;}
.day-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--ink-ghost);margin-top:3px;}
.day-now-tick{position:absolute;top:-2px;width:2px;height:9px;background:var(--ink);border-radius:1px;}

/* ── GOLDEN HOUR BOX ──────────────────────*/
.golden-box{display:flex;align-items:flex-start;gap:10px;background:var(--gold-bg);border:1px solid rgba(184,112,32,.15);border-radius:var(--r-sm);padding:12px 13px;margin-top:10px;}

/* ── ROUND BLOCKS ─────────────────────────*/
.round-blocks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;}
.round-block{border-radius:var(--r-sm);padding:12px 13px;border:1.5px solid transparent;}
.round-block.green{background:rgba(45,110,78,.08);border-color:rgba(45,110,78,.15);}
.round-block.yellow{background:rgba(184,112,32,.07);border-color:rgba(184,112,32,.15);}
.round-block.red{background:rgba(239,68,68,.07);border-color:rgba(239,68,68,.15);}
.round-block-holes{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-muted);margin-bottom:5px;}
.round-block-time{font-family:var(--font-display);font-size:20px;color:var(--ink);line-height:1;margin-bottom:2px;}
.round-block-finish{font-size:10px;color:var(--ink-sub);font-weight:300;margin-bottom:6px;}
.round-block-desc{font-size:11px;color:var(--ink-sub);font-weight:300;line-height:1.5;}

/* ── KLÄDGUIDE ────────────────────────────*/
.cloth-head{font-family:var(--font-display);font-size:17px;color:var(--ink);margin-bottom:6px;line-height:1.3;}
.cloth-reason{font-size:12px;color:var(--ink-sub);font-weight:300;line-height:1.6;margin-bottom:14px;}
.tags{display:flex;flex-wrap:wrap;gap:6px;}
.tag{display:inline-flex;align-items:center;padding:5px 11px;border-radius:20px;font-size:11px;font-weight:500;background:var(--surface-2);color:var(--ink-sub);border:1px solid var(--border-soft);letter-spacing:.1px;}
.tag.primary{background:rgba(45,110,78,.1);color:var(--sage);border-color:rgba(45,110,78,.18);}

/* ── VINDANALYS ───────────────────────────*/
.wind-analysis-block{padding:10px 12px;background:var(--surface-2);border-radius:var(--r-sm);margin-bottom:7px;}
.wind-analysis-block:last-of-type{margin-bottom:0;}
.wind-analysis-title{font-size:12px;font-weight:500;color:var(--ink);margin-bottom:3px;}
.wind-analysis-text{font-size:11px;color:var(--ink-sub);line-height:1.6;font-weight:300;}
.wind-pill{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border-radius:20px;padding:6px 12px;font-size:11px;color:var(--ink-sub);font-weight:400;margin-top:8px;}
.wind-arrow-dot{width:6px;height:6px;border-radius:50%;background:var(--sage-bright);}
.wind-sub{color:var(--ink-ghost);font-size:10px;margin-left:2px;}

/* ── TIMPROGNOS ───────────────────────────*/
.hour-outer{overflow-x:auto;scrollbar-width:none;margin:0 -2px;}
.hour-outer::-webkit-scrollbar{display:none;}
.hour-scroll{display:flex;gap:5px;padding:2px 2px 6px;width:max-content;}
.hour-tile{width:54px;background:var(--surface-2);border-radius:10px;padding:9px 6px 10px;text-align:center;border:1.5px solid transparent;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;}
.hour-tile.now{background:rgba(45,110,78,.1);border-color:rgba(45,110,78,.22);}
.hour-tile.daylight{border-color:rgba(245,158,11,.2);}
.hour-t{font-size:10px;font-weight:500;color:var(--ink-muted);letter-spacing:.2px;}
.hour-cond{font-size:15px;margin:2px 0;}
.hour-temp-v{font-family:var(--font-mono);font-size:14px;font-weight:400;color:var(--ink);}
.hour-wind-v{font-size:9px;color:var(--ink-muted);font-weight:400;}
.hour-precip{font-size:9px;color:#3b82f6;font-weight:400;min-height:12px;}

/* ── BÄSTA STARTTID ───────────────────────*/
.tee-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:16px;box-shadow:var(--shadow-card);}
.tee-slots{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap;}
.tee-slot{flex:1;min-width:60px;background:var(--surface-2);border-radius:var(--r-sm);padding:9px 10px;text-align:center;border:1.5px solid transparent;transition:border-color .15s,background .15s;}
.tee-slot.best{background:rgba(45,110,78,.1);border-color:rgba(45,110,78,.2);}
.tee-slot.good{background:rgba(245,158,11,.07);border-color:rgba(245,158,11,.17);}
.tee-slot-time{font-family:var(--font-mono);font-size:13px;font-weight:400;color:var(--ink);}
.tee-slot-idx{margin-top:3px;}
.tee-slot-idx-val{font-size:11px;font-weight:500;color:var(--ink-muted);}
.tee-slot.best .tee-slot-idx-val{color:var(--sage);}
.tee-peak-label{font-size:11px;color:var(--ink-muted);margin-top:10px;font-weight:300;letter-spacing:.1px;}

/* ── 5-DAGARS PROGNOS ─────────────────────*/
.day-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border-soft);}
.day-row:last-child{border-bottom:none;}
.day-row.best-day{background:rgba(45,110,78,.06);margin:0 -16px;padding:11px 16px;}
.day-name{font-size:13px;font-weight:500;color:var(--ink);}
.day-cond-badge{font-size:18px;line-height:1;}
.day-temps{white-space:nowrap;}
.day-hi{font-size:14px;font-weight:500;}
.day-lo{font-size:12px;color:var(--ink-muted);}
.best-day-badge{background:linear-gradient(135deg,var(--sage-mid),var(--sage));color:#fff;font-size:8px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:3px;box-shadow:0 2px 6px rgba(45,110,78,.22);}
.day-bar-wrap{height:3px;background:var(--surface-2);border-radius:2px;overflow:hidden;margin-top:2px;}

/* ── BUTTONS ──────────────────────────────*/
.update-btn{background:var(--ink);color:#fff;border:none;border-radius:var(--r);padding:14px 16px;font-family:var(--font-body);font-size:13px;font-weight:400;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.3px;transition:opacity .15s;box-shadow:0 4px 16px rgba(10,26,16,.18);}
.update-btn:hover{opacity:.84;}

/* ── PRIVACY SHEET ────────────────────────*/

/* ── RESPONSIVE ───────────────────────────*/
@media(max-width:400px){
  .hero-temp{font-size:68px;}
  .hero-club{font-size:20px;}
  main{padding:12px 11px 60px;}
  .two-col{grid-template-columns:1fr 1fr;}
}

/* ── PULL TO REFRESH ── */
.ptr-indicator{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-60px);z-index:500;pointer-events:none;background:var(--white);border-radius:0 0 20px 20px;padding:8px 20px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-sub);box-shadow:0 4px 16px rgba(10,26,16,.12);transition:transform .25s cubic-bezier(.22,1,.36,1);pointer-events:none;}
.ptr-indicator.visible{transform:translateX(-50%) translateY(0);}
.ptr-spin{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--sage);border-radius:50%;animation:spin .6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── HOME SCREEN ── */
.home-last-club{display:flex;align-items:center;gap:12px;background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow);}
.home-last-club:hover{border-color:var(--sage-mid);box-shadow:0 4px 16px rgba(61,122,92,.12);}
.home-last-icon{width:34px;height:34px;background:rgba(109,186,146,.1);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.home-last-label{font-size:10px;font-weight:500;letter-spacing:.8px;text-transform:uppercase;color:var(--sage);margin-bottom:2px;}
.home-last-name{font-size:14px;font-weight:500;color:var(--ink);}

.home-section-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted);margin:4px 0 8px;}

.home-about{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);}
.home-about-text{font-size:13px;color:var(--ink-sub);line-height:1.7;font-weight:300;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-soft);}
.home-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.home-feature{display:flex;align-items:flex-start;gap:10px;}
.home-feature-icon{width:28px;height:28px;background:rgba(109,186,146,.08);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.home-feature-title{font-size:12px;font-weight:500;color:var(--ink);margin-bottom:1px;}
.home-feature-sub{font-size:10px;color:var(--ink-muted);font-weight:300;line-height:1.4;}

.home-smhi-badge{display:flex;align-items:center;gap:7px;padding:10px 14px;background:var(--surface-2);border-radius:var(--r-sm);border:1px solid var(--border-soft);font-size:11px;color:var(--ink-muted);font-weight:300;}
.home-smhi-badge strong{font-weight:500;color:var(--ink-sub);}

.home-steps{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 18px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow);}
.home-step{display:flex;align-items:flex-start;gap:14px;}
.home-step-num{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--sage),var(--sage-mid));color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.home-step-text{font-size:13px;color:var(--ink-sub);line-height:1.55;font-weight:300;padding-top:3px;}

/* ── PULL TO REFRESH ── */
#ptr-indicator{position:fixed;top:-48px;left:50%;transform:translateX(-50%);z-index:500;pointer-events:none;display:flex;align-items:center;justify-content:center;transition:none;}
.ptr-spinner{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--sage);animation:spin .7s linear infinite;background:var(--white);box-shadow:0 2px 8px rgba(0,0,0,.12);}
@keyframes spin{to{transform:rotate(360deg);}}
/* ── AUTOCOMPLETE WEATHER ── */
.ac-wx{font-size:11px;color:rgba(255,255,255,.7);font-weight:400;white-space:nowrap;margin-left:2px;}
.ac-wx-loading{display:inline-block;width:20px;height:6px;border-radius:3px;background:rgba(255,255,255,.12);animation:shimmer 1.2s ease infinite;}
@keyframes shimmer{0%,100%{opacity:.3;}50%{opacity:.8;}}


/* ── BOLLPÅVERKAN ── */
.ball-clubs{display:flex;flex-direction:column;gap:5px;}
.ball-club-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--surface-2);border-radius:var(--r-sm);}
.ball-club-name{flex:1;font-size:12px;color:var(--ink-sub);font-weight:400;}
.ball-club-adj{font-size:13px;font-weight:600;font-family:var(--font-mono);min-width:36px;text-align:right;}
.ball-club-result{font-size:12px;color:var(--ink-muted);font-family:var(--font-mono);min-width:40px;text-align:right;}
