/* ════════════════════════════════════════════════════════════════════════
   vädret.org — главная таблица стилей
   ════════════════════════════════════════════════════════════════════════
   Палитра / типографика — основа из дизайна frontend/index.html.
   Mobile-first: добавлены @media для ≤850px (tablet) и ≤480px (phone).
*/

/* Self-hosted webfonts (Fontsource, latin subset) — CLS=0, no network round-trip */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:300;font-display:swap;src:url('/assets/fonts/hanken-grotesk-300.woff2') format('woff2');}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/hanken-grotesk-400.woff2') format('woff2');}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/hanken-grotesk-500.woff2') format('woff2');}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/hanken-grotesk-600.woff2') format('woff2');}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/hanken-grotesk-700.woff2') format('woff2');}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:800;font-display:swap;src:url('/assets/fonts/hanken-grotesk-800.woff2') format('woff2');}
@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/instrument-serif-400.woff2') format('woff2');}
@font-face{font-family:'Instrument Serif';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/instrument-serif-400-italic.woff2') format('woff2');}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/dm-mono-400.woff2') format('woff2');}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/dm-mono-500.woff2') format('woff2');}

:root{
  --blue:#0057B8;--blue-dk:#003D82;--blue-lt:#EBF3FF;--blue-mid:#1A6FCC;
  --yellow:#FECC00;--red:#C0000A;--green:#15803D;--orange:#C25800;--cold:#2870A0;
  --ink:#0F0F0F;--sub:#3A3A3A;--muted:#6A6A6A;--faint:#AAAAAA;
  --rule:#E5E5E5;--bg:#F4F4F2;--white:#FFFFFF;
  --serif:'Instrument Serif',Georgia,serif;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
  --mono:'DM Mono',monospace;
  --W:1320px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:var(--blue);text-decoration:none;cursor:pointer;}
a:hover{text-decoration:underline;}
img{max-width:100%;height:auto;}

/* NAV */
.nav{background:var(--blue-dk);height:58px;display:flex;align-items:center;padding:0 52px;position:sticky;top:0;z-index:100;}
.logo{font-family:var(--serif);font-size:23px;font-style:italic;color:#fff;margin-right:36px;flex-shrink:0;}
.logo b{font-style:normal;color:var(--yellow);}
.logo:hover{text-decoration:none;}
.nav-links{display:flex;gap:0;flex:1;overflow-x:auto;scrollbar-width:none;}
.nav-links::-webkit-scrollbar{display:none;}
.nl{height:58px;display:flex;align-items:center;padding:0 18px;font-size:15px;font-weight:600;color:rgba(255,255,255,.7);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:.2px;transition:.1s;}
.nl:hover{color:#fff;text-decoration:none;}
.nl.on{color:#fff;border-bottom-color:var(--yellow);}
.nav-end{margin-left:auto;display:flex;align-items:center;gap:10px;}
.loc{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:rgba(255,255,255,.6);}
.loc:hover{text-decoration:none;color:#fff;}
.loc-dot{width:6px;height:6px;border-radius:50%;background:var(--yellow);display:inline-block;}
.srch-form{display:flex;gap:6px;align-items:center;}
.srch{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:7px;padding:6px 13px;font:14px var(--sans);color:#fff;width:190px;}
.srch::placeholder{color:rgba(255,255,255,.3);}
.srch:focus{outline:none;background:rgba(255,255,255,.16);}
.srch-btn{background:var(--yellow);color:var(--blue-dk);border:none;border-radius:7px;padding:6px 18px;font:700 13px var(--sans);cursor:pointer;}
.lang-switch{display:flex;gap:4px;margin-left:8px;}
.lang-switch a{font-size:11px;font-weight:700;color:rgba(255,255,255,.4);padding:3px 6px;border-radius:4px;}
.lang-switch a:hover{color:#fff;text-decoration:none;}
.lang-switch a.on{color:var(--blue-dk);background:var(--yellow);}

/* TICKER */
.ticker{background:var(--blue-dk);border-top:2px solid var(--yellow);overflow:hidden;padding:6px 0;position:relative;}
.tt{position:absolute;left:0;top:0;bottom:0;z-index:2;background:rgba(0,0,0,.25);color:var(--yellow);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:0 14px;display:flex;align-items:center;}
.ts{display:inline-block;white-space:nowrap;animation:run 32s linear infinite;color:rgba(255,255,255,.75);font-size:13px;padding-left:105px;}
@keyframes run{from{transform:translateX(55%)}to{transform:translateX(-100%)}}

/* WARN */
.warn{background:#FEF3C7;border-bottom:1px solid #FDE68A;padding:9px 52px;display:flex;gap:10px;align-items:center;font-size:14px;}
.wb{background:#B45309;color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:3px;flex-shrink:0;letter-spacing:.5px;}
.wt b{color:#92400E;}

/* CURRENT */
.current{background:var(--white);border-bottom:1px solid var(--rule);}
.cur-in{max-width:var(--W);margin:0 auto;padding:38px 52px 34px;display:grid;grid-template-columns:auto 1fr auto;gap:0;align-items:center;}
.cur-loc{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.cur-loc::before{content:'';width:16px;height:1px;background:var(--blue);}
.cur-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
.cur-ico{font-size:68px;line-height:1;margin-top:12px;}
.cur-num{font-family:var(--serif);font-size:152px;font-weight:400;line-height:.82;color:var(--ink);letter-spacing:-5px;}
.cur-deg{font-family:var(--serif);font-size:60px;font-weight:400;color:var(--faint);vertical-align:super;letter-spacing:0;}
.cur-cond{font-family:var(--serif);font-size:26px;font-style:italic;color:var(--sub);margin-top:10px;}
.cur-feel{font-size:15px;color:var(--muted);margin-top:4px;}
.cur-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:14px;}
.ctag{background:var(--blue-lt);border:1px solid rgba(0,87,184,.15);border-radius:5px;padding:5px 14px;font-size:13px;font-weight:500;color:var(--blue);}

.cur-m{padding:0 52px;border-left:1px solid var(--rule);border-right:1px solid var(--rule);margin:0 44px;}
.mm-row{display:flex;gap:14px;margin-bottom:20px;}
.mm{flex:1;text-align:center;padding:14px;background:var(--bg);border-radius:8px;}
.mm-l{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:5px;}
.mm-v{font-family:var(--serif);font-size:36px;color:var(--ink);}
.sun-g{display:grid;grid-template-columns:1fr 1fr;gap:6px 20px;}
.sg{display:flex;flex-direction:column;padding:4px 0;}
.sg-l{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--faint);margin-bottom:2px;}
.sg-v{font-size:17px;font-weight:600;color:var(--ink);}

.cur-r{}
.stat{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--rule);gap:22px;}
.stat:first-child{border-top:1px solid var(--rule);}
.stat:last-child{border-bottom:none;}
.sl{font-size:13px;font-weight:500;color:var(--muted);}
.sv{font-family:var(--mono);font-size:16px;color:var(--ink);}

/* HOURLY */
.hourly{background:var(--white);border-bottom:1px solid var(--rule);}
.h-in{max-width:var(--W);margin:0 auto;padding:0 52px;}
.h-scroll{display:flex;overflow-x:auto;scrollbar-width:none;}
.h-scroll::-webkit-scrollbar{display:none;}
.hc{flex:0 0 84px;padding:16px 6px;text-align:center;border-right:1px solid var(--rule);cursor:pointer;transition:.1s;text-decoration:none;color:inherit;}
.hc:last-child{border-right:none;}
.hc:hover{background:var(--bg);text-decoration:none;}
.hc.now{background:var(--blue-lt);}
.hc.now .ht{color:var(--blue);font-weight:700;}
.ht{font-size:12px;font-weight:500;color:var(--faint);margin-bottom:7px;letter-spacing:.3px;}
.hi{font-size:26px;margin-bottom:7px;}
.hv{font-family:var(--mono);font-size:17px;color:var(--ink);font-weight:600;}
.hr{font-size:11px;color:var(--cold);margin-top:3px;font-weight:600;}
.hw{font-size:11px;color:var(--muted);margin-top:2px;font-weight:500;font-family:var(--mono);}

/* PAGE */
.page{max-width:var(--W);margin:0 auto;padding:38px 52px;}
.two{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px;}
.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:22px;}
.four{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;}
.six{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:22px;}
.risk-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:16px;margin-bottom:22px;}

/* CARD */
.card{background:var(--white);border-radius:12px;border:1px solid var(--rule);overflow:hidden;}
.ch{padding:17px 22px 15px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;}
.ch h2{font-family:var(--serif);font-size:24px;font-weight:400;}
.ch a{font-size:13px;color:var(--blue);}
.ch small{font-size:12px;color:var(--muted);}
.cb{padding:20px 22px;}

/* SECTION LABEL */
.slbl{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint);margin-bottom:18px;display:flex;align-items:center;gap:12px;}
.slbl::after{content:'';flex:1;height:1px;background:var(--rule);}

/* FORECAST */
.frow{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--rule);cursor:pointer;transition:.1s;color:inherit;text-decoration:none;}
.frow:last-child{border-bottom:none;}
.frow:hover{background:rgba(0,0,0,.02);margin:0 -22px;padding:14px 22px;text-decoration:none;}
.fd{width:100px;font-size:18px;font-weight:600;}
.fi{font-size:26px;flex-shrink:0;}
.fc{flex:1;font-size:16px;color:var(--muted);font-style:italic;}
.fb{display:flex;align-items:baseline;gap:10px;margin-left:auto;}
.fhi{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--red);}
.flo{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--cold);}
.frain{font-size:14px;color:var(--cold);font-weight:600;min-width:40px;text-align:right;}

/* INDEX */
.irow{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--rule);transition:.1s;}
.irow:last-child{border-bottom:none;}
.iem{font-size:24px;flex-shrink:0;}
.itx{flex:1;}
.ilbl{font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--faint);margin-bottom:3px;}
.ival{font-size:20px;font-weight:700;}
.isub{font-size:14px;color:var(--muted);}
.g{color:var(--green);}.o{color:var(--orange);}.r{color:var(--red);}.b{color:var(--cold);}

/* DATA TILES */
.dtile{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:22px 24px;}
.dtl{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--faint);margin-bottom:10px;}
.dtv{font-family:var(--mono);font-size:36px;color:var(--ink);letter-spacing:-1px;line-height:1;}
.dtu{font-size:16px;color:var(--faint);letter-spacing:0;}
.dts{font-size:14px;color:var(--muted);margin-top:7px;}
.dtbar{height:3px;background:var(--rule);margin-top:12px;border-radius:2px;}
.dtbar div{height:100%;background:var(--blue);border-radius:2px;}

/* POLLEN */
.prow{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--rule);font-size:16px;}
.prow:last-child{border-bottom:none;}
.pn{flex:1;color:var(--sub);}
.pbar{width:72px;height:5px;background:var(--rule);border-radius:3px;}
.pbar div{height:100%;border-radius:3px;}
.p0{background:var(--faint);}.p1{background:#22C55E;}.p2{background:#F59E0B;}.p3{background:#EF4444;}.p4{background:#7C3AED;}
.plvl{width:50px;text-align:right;font-size:13px;font-weight:700;}

/* SWIM */
.srow{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--rule);font-size:16px;}
.srow:last-child{border-bottom:none;}
.sp{flex:1;}
.stemp{font-family:var(--mono);font-size:21px;}

/* REGIONS */
.reg-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:22px 24px;cursor:pointer;transition:.12s;display:block;color:inherit;text-decoration:none;}
.reg-card:hover{border-color:var(--blue);transform:translateY(-2px);text-decoration:none;}
.reg-nm{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.reg-tmp{font-family:var(--serif);font-size:64px;color:var(--ink);line-height:1;margin-bottom:5px;}
.reg-tmp small{font-size:28px;color:var(--faint);}
.reg-cond{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--sub);margin-bottom:10px;}
.reg-meta{font-size:14px;color:var(--muted);}

/* CITIES */
.city-card{background:var(--white);border:1px solid var(--rule);border-radius:10px;padding:15px 16px;cursor:pointer;transition:.1s;display:flex;align-items:center;gap:11px;color:inherit;text-decoration:none;}
.city-card:hover{border-color:var(--blue);background:var(--blue-lt);text-decoration:none;}
.cico{font-size:22px;flex-shrink:0;}
.cinf{flex:1;min-width:0;}
.cnm{font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ccd{font-size:13px;color:var(--muted);}
.ctmp{font-family:var(--serif);font-size:30px;}

/* FJÄLL */
.fj-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:18px 20px;cursor:pointer;transition:.12s;display:block;color:inherit;text-decoration:none;}
.fj-card:hover{border-color:var(--cold);text-decoration:none;}
.fj-nm{font-size:17px;font-weight:700;margin-bottom:3px;}
.fj-reg{font-size:13px;color:var(--muted);margin-bottom:12px;}
.fj-row{display:flex;justify-content:space-between;align-items:center;}
.fj-tmp{font-family:var(--serif);font-size:40px;}
.fj-ico{font-size:28px;}
.fj-snow{font-size:13px;color:var(--cold);font-weight:700;margin-top:6px;}

/* SUN / ROAD */
.sun-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--rule);font-size:16px;}
.sun-row:last-child{border-bottom:none;}
.sun-l{color:var(--muted);}
.sun-v{font-weight:600;}

.rrow{display:flex;gap:10px;padding:11px 0;border-bottom:1px solid var(--rule);font-size:15px;align-items:flex-start;}
.rrow:last-child{border-bottom:none;}
.rico{font-size:16px;flex-shrink:0;margin-top:2px;}
.rt{color:var(--sub);line-height:1.5;}
.rt b{color:var(--ink);}

/* EDITORIAL */
.editorial{background:var(--blue-dk);border-radius:12px;padding:28px 32px;margin-bottom:22px;}
.ed-tag{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:9px;}
.ed-title{font-family:var(--serif);font-size:26px;font-style:italic;color:#fff;line-height:1.4;margin-bottom:10px;}
.ed-body{font-size:15px;color:rgba(255,255,255,.55);line-height:1.75;}
.ed-foot{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;}
.smhi-badge{font-family:var(--serif);font-size:19px;letter-spacing:3px;color:#fff;}
.smhi-upd{font-size:13px;color:var(--yellow);font-weight:600;}

/* P4 */
.p4-row{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:18px 22px;display:flex;align-items:center;gap:16px;margin-bottom:22px;}
.p4-ico{font-size:30px;}
.p4-name{font-family:var(--serif);font-size:20px;color:var(--ink);}
.p4-name em{color:var(--blue);font-style:normal;}
.p4-sub{font-size:14px;color:var(--muted);margin-top:3px;}
.p4-right{margin-left:auto;font-size:13px;color:var(--muted);text-align:right;line-height:1.6;}

/* CHART */
.chart-box{margin-bottom:22px;}
.chart-lbl{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--faint);padding:16px 22px 14px;border-bottom:1px solid var(--rule);}
.chart-body{padding:18px 22px 14px;}
.cleg{display:flex;gap:16px;font-size:13px;color:var(--muted);margin-top:10px;flex-wrap:wrap;}
.cleg span{display:flex;align-items:center;gap:6px;}
.cl{width:18px;height:2.5px;border-radius:1px;}

/* SMHI STRIP */
.smhi-strip{background:var(--ink);padding:18px 52px;display:flex;align-items:center;gap:24px;margin-top:8px;}
.smhi-logo{font-family:var(--serif);font-size:24px;letter-spacing:3px;color:#fff;flex-shrink:0;}
.strip-div{width:1px;height:30px;background:rgba(255,255,255,.1);}
.strip-txt{font-size:13px;color:rgba(255,255,255,.35);flex:1;}
.strip-upd{font-size:13px;color:var(--yellow);font-weight:600;white-space:nowrap;}

/* FOOTER */
.footer{background:var(--blue-dk);padding:28px 52px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;}
.ft-logo{font-family:var(--serif);font-size:20px;font-style:italic;color:#fff;}
.ft-logo b{font-style:normal;color:var(--yellow);}
.ft-logo:hover{text-decoration:none;}
.ft-links{display:flex;gap:20px;flex-wrap:wrap;}
.ft-links a{font-size:13px;color:rgba(255,255,255,.4);}
.ft-links a:hover{color:#fff;text-decoration:none;}
.ft-lang{display:flex;gap:4px;}
.ft-lang a{font-size:11px;font-weight:700;color:rgba(255,255,255,.4);padding:3px 6px;border-radius:4px;}
.ft-lang a.on{color:var(--blue-dk);background:var(--yellow);}
.ft-copy{font-size:12px;color:rgba(255,255,255,.2);width:100%;text-align:center;}

/* SWEDEN MAP */
/* Leaflet temperaturkarta — без content-visibility (ломает Leaflet measurements).
   Map-card simple position:relative. */
.map-card{position:relative;}
.map-wrap{padding:20px;display:flex;justify-content:center;align-items:flex-start;gap:32px;}
.sweden-map{flex-shrink:0;}
.map-legend{flex:1;display:flex;flex-direction:column;gap:12px;}
.map-city-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--rule);font-size:15px;color:inherit;text-decoration:none;}
.map-city-row:last-child{border-bottom:none;}
.map-city-row:hover{background:rgba(0,87,184,.04);text-decoration:none;}
.map-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.map-city-nm{flex:1;font-weight:600;}
.map-city-cond{font-size:13px;color:var(--muted);font-style:italic;}
.map-city-tmp{font-family:var(--serif);font-size:20px;font-weight:400;}

/* DAYLIGHT CHART */
.daylight-chart{width:100%;}
.dl-month-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;}
.dl-month{width:50px;font-size:12px;font-weight:600;color:var(--muted);}
.dl-bar-wrap{flex:1;height:18px;background:var(--rule);border-radius:3px;overflow:hidden;position:relative;}
.dl-bar-inner{display:flex;height:100%;width:100%;}
.dl-dark-seg{background:#1A3A5A;}
.dl-twi-seg{background:#4A7AB8;}
.dl-sun-seg{background:#FECC00;}
.dl-hrs{font-family:var(--mono);font-size:13px;color:var(--muted);min-width:50px;text-align:right;}
.dl-today{border:2px solid var(--orange) !important;box-shadow:0 0 0 1px rgba(194,88,0,.2);}

/* BLIXT */
.blixt-wrap{background:linear-gradient(135deg,#1A1A2E,#2A2A4E);border-radius:8px;padding:16px;text-align:center;margin-bottom:14px;}
.blixt-title{font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:8px;}
.blixt-count{font-family:var(--serif);font-size:48px;color:#FECC00;}
.blixt-sub{font-size:13px;color:rgba(255,255,255,.4);margin-top:4px;}

/* BRANDRISK */
.br-scale{display:flex;gap:4px;margin:10px 0;}
.br-seg{flex:1;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:rgba(255,255,255,.8);}
.br-active{box-shadow:0 0 0 2px var(--ink),0 0 0 4px rgba(0,0,0,.2);}


/* FEATURE CARDS ───────────────────────────────────────────────────────────
   Сетка 4×N карточек на главной для разделов (pollen, UV, bad, fjäll, ...).
   Цвет акцента приходит из inline --feat-accent / --feat-bg. */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px;}
.feat-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:20px 18px 16px;display:flex;flex-direction:column;gap:10px;color:inherit;text-decoration:none;transition:.12s;position:relative;overflow:hidden;}
.feat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--feat-accent,var(--blue));}
.feat-card:hover{border-color:var(--feat-accent,var(--blue));transform:translateY(-2px);box-shadow:0 6px 18px -8px rgba(0,0,0,.12);text-decoration:none;}
.feat-ico{width:42px;height:42px;border-radius:10px;background:var(--feat-bg,var(--blue-lt));display:flex;align-items:center;justify-content:center;font-size:22px;}
.feat-body h3{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);margin-bottom:4px;line-height:1.2;}
.feat-body p{font-size:13px;color:var(--muted);line-height:1.45;}
.feat-cta{margin-top:auto;padding-top:8px;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--feat-accent,var(--blue));}

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE — tablet ≤ 850px
   ════════════════════════════════════════════════════════════════════════*/
@media (max-width:850px){
  .nav{padding:0 16px;height:auto;flex-wrap:wrap;}
  .nav-end{order:2;width:100%;padding:8px 0;gap:8px;justify-content:flex-start;flex-wrap:wrap;}
  .nav-links{order:3;width:100%;padding-bottom:4px;}
  .nl{padding:0 12px;height:48px;font-size:12px;}
  .srch{width:140px;}
  .loc{font-size:12px;}

  .warn{padding:9px 16px;}

  /* ───────────────────────────────────────────────────────────────────────
     HERO — компактнее, sans-only (быстрее без serif на мобиле)
     ─────────────────────────────────────────────────────────────────────── */
  .cur-in{display:flex;flex-direction:column;padding:18px 16px 14px;gap:12px;}
  .cur-l{order:1;}
  .cur-r{order:2;}
  .cur-m{order:3;}
  .cur-loc{font-size:11px;letter-spacing:1.5px;margin-bottom:8px;}
  .cur-row{align-items:center;gap:10px;margin-bottom:4px;}
  .cur-ico{font-size:42px;margin-top:0;}
  .cur-num{font-family:var(--sans);font-size:68px;font-weight:700;letter-spacing:-2px;line-height:1;}
  .cur-deg{font-family:var(--sans);font-size:28px;font-weight:400;vertical-align:super;}
  .cur-cond{font-family:var(--sans);font-size:17px;font-style:normal;font-weight:500;margin-top:4px;color:var(--ink);}
  .cur-feel{font-size:13px;margin-top:2px;}
  .cur-tags{gap:5px;margin-top:8px;}
  .ctag{padding:4px 10px;font-size:11px;}

  /* Mätvärden внутри hero (cur-m) — без рамок, компактнее */
  .cur-m{margin:0;padding:12px 0;border:none;border-top:1px solid var(--rule);}
  .mm-row{gap:8px;margin-bottom:12px;}
  .mm{padding:8px 4px;}
  .mm-l{font-size:9px;letter-spacing:1px;}
  .mm-v{font-family:var(--sans);font-weight:700;font-size:20px;}
  .sun-g{grid-template-columns:1fr 1fr;gap:4px 14px;}
  .sg-l{font-size:10px;}
  .sg-v{font-size:14px;}

  /* Cur-r (key stats) — компактнее */
  .cur-r{padding-top:8px;border-top:1px solid var(--rule);}
  .stat{padding:7px 0;gap:14px;}
  .stat:first-child{border-top:none;}
  .sl{font-size:12px;}
  .sv{font-size:14px;}

  /* ───────────────────────────────────────────────────────────────────────
     HOURLY — компактнее
     ─────────────────────────────────────────────────────────────────────── */
  .h-in{padding:0 16px;}
  .hc{flex:0 0 64px;padding:10px 4px;}
  .ht{font-size:10px;}
  .hi{font-size:20px;margin-bottom:4px;}
  .hv{font-size:14px;}
  .hr{font-size:10px;}

  /* ───────────────────────────────────────────────────────────────────────
     PAGE — общие отступы
     ─────────────────────────────────────────────────────────────────────── */
  .page{padding:18px 14px;}
  .two{grid-template-columns:1fr;gap:14px;}
  .three{grid-template-columns:1fr;gap:14px;}
  .four{grid-template-columns:1fr 1fr;gap:10px;}
  .feat-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .six{grid-template-columns:1fr 1fr;}
  .risk-grid{grid-template-columns:1fr 1fr;}
  .slbl{font-size:10px;letter-spacing:1.5px;margin-bottom:12px;}

  /* CARD — sans headings, меньше padding */
  .ch{padding:12px 16px 10px;}
  .ch h2{font-family:var(--sans);font-size:15px;font-weight:700;}
  .cb{padding:14px 16px;}

  /* ───────────────────────────────────────────────────────────────────────
     DAY-ROWS — YR-style compact
     ─────────────────────────────────────────────────────────────────────── */
  .frow{padding:11px 0;gap:10px;}
  .fd{width:84px;font-size:13px;font-weight:600;}
  .fi{font-size:22px;flex-shrink:0;}
  .fc{font-size:12px;}
  .fhi{font-family:var(--sans);font-size:18px;font-weight:700;}
  .flo{font-family:var(--sans);font-size:14px;font-weight:500;}
  .frain{font-size:11px;}
  .frow:hover{margin:0;padding:11px 0;}

  /* ───────────────────────────────────────────────────────────────────────
     FEATURE CARDS — компактнее
     ─────────────────────────────────────────────────────────────────────── */
  .feat-card{padding:14px 12px 12px;gap:6px;}
  .feat-ico{width:36px;height:36px;font-size:18px;}
  .feat-body h3{font-family:var(--sans);font-size:15px;font-weight:700;}
  .feat-body p{font-size:11px;}
  .feat-cta{font-size:10px;padding-top:4px;}

  /* ───────────────────────────────────────────────────────────────────────
     MAP — компактно
     ─────────────────────────────────────────────────────────────────────── */
  .map-wrap{flex-direction:column;align-items:center;gap:14px;padding:14px;}
  .sweden-map{max-width:260px;height:auto;}

  /* SMHI/footer */
  .smhi-strip{padding:14px;flex-wrap:wrap;}
  .smhi-strip .strip-div{display:none;}
  .strip-upd{margin-left:auto;}
  .footer{padding:18px 14px;}
  .ft-copy{order:3;}

  /* ───────────────────────────────────────────────────────────────────────
     СКРЫВАЕМ ЛИШНЕЕ НА МОБИЛЕ (быстрее, чище)
     ─────────────────────────────────────────────────────────────────────── */
  /* Editorial blocks (sources/about) — экономим ~250px вертикально */
  .editorial{display:none;}
  /* Daylight chart — тяжёлый, на главной экономим */
  .chart-box{display:none;}
  /* Sweden map card — compact на мобиле, не скрываем (но Leaflet height меньше) */
  .map-card #homeMap{height:380px !important;}
  /* Hero h1 на langtid/klimat/etc — меньше */
  .page > h1{font-size:32px !important;line-height:1.1;margin-bottom:6px;}
  .page > p{font-size:13px;margin-bottom:16px;}

  /* DTILE — компактнее */
  .dtile{padding:14px 14px;}
  .dtl{font-size:10px;letter-spacing:1.5px;}
  .dtv{font-family:var(--sans);font-size:24px;}

  /* REG-CARD — компактнее */
  .reg-card{padding:14px 16px;}
  .reg-tmp{font-family:var(--sans);font-size:38px;}
  .reg-cond{font-size:14px;font-style:normal;}

  /* CITY-CARD — компактнее */
  .city-card{padding:11px 12px;gap:8px;}
  .cico{font-size:18px;}
  .cnm{font-size:13px;}
  .ccd{font-size:11px;}
  .ctmp{font-family:var(--sans);font-size:20px;font-weight:700;}

  /* FJ-CARD */
  .fj-card{padding:14px 14px;}
  .fj-nm{font-size:14px;}
  .fj-tmp{font-family:var(--sans);font-size:30px;font-weight:700;}

  /* P4 row */
  .p4-row{padding:12px 14px;}
  .p4-name{font-family:var(--sans);font-size:15px;font-weight:600;}
}

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE — phone ≤ 480px
   ════════════════════════════════════════════════════════════════════════*/
@media (max-width:480px){
  body{font-size:15px;}
  .cur-num{font-size:78px;letter-spacing:-2px;}
  .cur-deg{font-size:30px;}
  .cur-ico{font-size:40px;}
  .sun-g{grid-template-columns:1fr;}
  .four{grid-template-columns:1fr;}
  .feat-grid{grid-template-columns:1fr;}
  .six{grid-template-columns:1fr 1fr;}
  .risk-grid{grid-template-columns:1fr;}
  .mm-row{flex-direction:column;}

  .ed-title{font-size:20px;}
  .editorial{padding:22px 18px;}

  .ch{padding:14px 16px 12px;}
  .ch h2{font-size:18px;}
  .cb{padding:16px;}

  .fhi{font-size:22px;}
  .flo{font-size:17px;}
  .fd{width:72px;font-size:15px;}
  .fi{font-size:22px;}
}

/* Print friendly */
@media print{
  .nav, .ticker, .warn, .footer, .smhi-strip{display:none;}
  .page{padding:0;}
  body{background:#fff;}
}
