/*
Theme Name: TeknikFix Redesign
Template: teknikfix
Version: 0.5.0
*/


/* Hallmark · macrostructure: Editorial Commerce · tone: premium-trustworthy · anchor hue: sky-blue
 * pre-emit critique: P5 H4 E4 S4 R4 V4 · honest-copy: no fabricated ratings/discounts/testimonials */
:root{
  --paper:oklch(99.3% 0.004 255); --paper-2:oklch(97.6% 0.008 250); --paper-3:oklch(96% 0.013 250);
  --surface:oklch(99.6% 0.0025 255);
  --ink:oklch(26% 0.022 260); --ink-2:oklch(44% 0.02 258); --muted:oklch(57% 0.018 258);
  --accent:oklch(61% 0.19 255); --accent-deep:oklch(49% 0.18 257);
  --accent-50:oklch(96% 0.035 252); --accent-100:oklch(89% 0.08 253);
  --line:oklch(92.5% 0.006 250); --line-2:oklch(88% 0.01 250);
  --font-display:"Manrope",system-ui,sans-serif;
  --font-body:"Manrope",system-ui,sans-serif;
  --font-serif:"Fraunces",Georgia,serif;
  --hero-block:oklch(92% 0.065 250);
  --shadow-sm:0 1px 2px oklch(27% 0.02 258/.05);
  --shadow:0 2px 6px oklch(27% 0.02 258/.05),0 12px 28px oklch(27% 0.02 258/.07);
  --shadow-lg:0 18px 50px oklch(27% 0.04 258/.14);
  --r-sm:6px; --r:8px; --r-lg:12px; --r-xl:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --space:clamp(42px,5vw,78px);
  --maxw:1200px;
}
*{box-sizing:border-box}
html,body{overflow-x:clip}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;letter-spacing:-.02em;line-height:1.08;font-weight:600;overflow-wrap:anywhere}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-body);font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep)}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;padding:.95rem 1.8rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.2s var(--ease);white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff;box-shadow:0 8px 20px oklch(61% 0.19 255/.36)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 10px 26px oklch(61% 0.19 255/.44)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-deep)}
.section{padding:var(--space) 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:40px}
.sec-head h2{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700}
.sec-head .sub{margin:.6rem 0 0;color:var(--muted);font-size:1.02rem;max-width:42ch}
.more{color:var(--accent-deep);font-weight:600;font-size:.95rem;display:inline-flex;gap:.4rem;align-items:center;white-space:nowrap}
.more:hover{gap:.65rem}

/* topbar */
.topbar{background:var(--ink);color:oklch(82% 0.02 250);font-size:.8rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:16px;flex-wrap:wrap}
.topbar .seg{display:flex;gap:22px}
.topbar a{color:oklch(82% 0.02 250)}.topbar a:hover{color:#fff}
.topbar a.active{color:#fff;font-weight:600}

/* header */
header{position:sticky;top:0;z-index:50;background:oklch(100% 0 0/.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:22px;height:74px;flex-wrap:nowrap}
.logo{font-family:var(--font-display);font-weight:700;font-size:1.4rem;letter-spacing:-.04em}
.logo b{color:var(--accent);font-weight:700}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:30px;width:auto;display:block}
.brand .tag{font-family:var(--font-body);font-size:.72rem;line-height:1.2;color:var(--muted);border-left:1px solid var(--line-2);padding-left:13px;max-width:132px}
@media(max-width:640px){.brand .tag{display:none}}
.nav nav{display:flex;gap:20px;font-weight:500;font-size:.95rem;flex:none}
.nav nav a{position:relative;padding:.2rem 0;white-space:nowrap}
.nav nav a:hover{color:var(--accent-deep)}
.nav .spacer{flex:1}
.search{display:flex;align-items:center;gap:.6rem;background:var(--paper-2);border:1px solid var(--line-2);border-radius:999px;padding:.78rem 1.1rem;color:var(--muted);width:clamp(180px,22vw,290px);min-width:0;flex:none;font-size:.92rem;transition:.2s}
.search:hover{border-color:var(--line-2)}
.icns{display:flex;gap:16px;align-items:center;color:var(--ink-2)}
.icns a:hover{color:var(--accent-deep)}
.icns .badge{position:relative}
.icns .badge i{position:absolute;top:-7px;right:-9px;background:var(--accent);color:#fff;font-size:.62rem;font-weight:700;border-radius:9px;padding:0 5px;font-style:normal}

/* hero */
.hero{position:relative;overflow:hidden;background:var(--hero-block)}
.hero .wrap{display:grid;grid-template-columns:1fr 1.08fr;gap:48px;align-items:center;padding:clamp(48px,6vw,88px) 24px}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:700;letter-spacing:-.035em}
h1 em,h2 em,h3 em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.01em;color:var(--accent-deep)}
.hero .lead{font-size:1.15rem;color:var(--ink-2);margin:1.3rem 0 0;max-width:34ch}
.hero .cta{display:flex;gap:14px;margin-top:2rem;flex-wrap:wrap}
.hero .facts{display:flex;gap:10px;margin-top:2rem;flex-wrap:wrap}
.fact{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5rem .9rem;font-size:.83rem;font-weight:500;color:var(--ink-2);box-shadow:var(--shadow-sm)}
.fact svg{color:var(--accent-deep);flex:none}
.hero-visual{position:relative}
.hero-visual .glow{position:absolute;inset:6% 0 6% 0;background:radial-gradient(58% 56% at 60% 46%,var(--accent-100),transparent 72%);filter:blur(6px);z-index:0}
.hero-visual img{position:relative;z-index:1;width:100%;border-radius:var(--r-lg)}
.float-card{position:absolute;z-index:2;bottom:18px;left:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:.75rem .9rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.7rem}
.float-card .pc-ic{width:38px;height:38px;border-radius:10px;background:var(--accent-50);display:grid;place-items:center;color:var(--accent-deep);flex:none}
.float-card small{display:block;color:var(--muted);font-size:.72rem;font-weight:500}
.float-card b{font-family:var(--font-display);font-size:.98rem}
.hero-ctrl{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);width:min(100% - 48px,var(--maxw));display:flex;justify-content:space-between;align-items:center;z-index:4;pointer-events:none}
.hero-ctrl .dots{display:flex;gap:8px;align-items:center}
.hero-ctrl .dots span{width:9px;height:9px;border-radius:50%;background:var(--ink);opacity:.22}
.hero-ctrl .dots span.on{opacity:1;width:28px;border-radius:5px}
.hero-ctrl .arrows{display:flex;gap:10px;pointer-events:auto}
.hero-ctrl .arrows button{width:48px;height:48px;border-radius:50%;border:0;background:var(--ink);color:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;transition:.18s}
.hero-ctrl .arrows button:hover{background:var(--accent-deep)}

/* trust strip */
.strip{border-bottom:1px solid var(--line);background:#fff}
.strip .wrap{display:flex;justify-content:center;flex-wrap:wrap;gap:13px;padding:30px 24px}
.strip .it{display:flex;gap:.55rem;align-items:center;border:1px solid var(--line-2);border-radius:999px;padding:.62rem 1.25rem}
.strip .ic{flex:none;width:28px;height:28px;border-radius:50%;background:var(--accent-50);display:grid;place-items:center;color:var(--accent-deep)}
.strip .ic svg{width:16px;height:16px}
.strip h4{font-family:var(--font-body);font-size:.9rem;font-weight:600;margin:0;color:var(--ink)}
.strip p{display:none}

/* categories */
.cats{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}
.cat{position:relative;text-align:center;transition:.22s var(--ease)}
.cat:hover{transform:translateY(-4px)}
.cat:hover .iw{box-shadow:var(--shadow-lg)}
.cat .iw{height:148px;display:grid;place-items:center;margin-bottom:14px;background:var(--accent-50);border-radius:18px;padding:22px;transition:.22s var(--ease)}
.cat img{max-height:88px;width:auto;object-fit:contain;mix-blend-mode:multiply}
.cat h4{font-family:var(--font-body);font-size:.92rem;font-weight:700;margin:0}
.cat span{font-size:.78rem;color:var(--muted)}
.cat .ar{position:absolute;top:12px;right:12px;width:26px;height:26px;border-radius:8px;background:var(--paper-2);display:grid;place-items:center;color:var(--accent-deep);opacity:0;transform:translateX(-4px);transition:.22s}
.cat:hover .ar{opacity:1;transform:none}

/* product cards */
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s var(--ease)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--accent-100)}
.card .media{position:relative;background:var(--paper-2);aspect-ratio:4/3;display:grid;place-items:center;padding:20px}
.card .media img{max-height:100%;width:auto;object-fit:contain;mix-blend-mode:multiply}
.chip{position:absolute;top:12px;left:12px;font-size:.7rem;font-weight:700;padding:.26rem .6rem;border-radius:999px;background:#fff;color:var(--accent-deep);border:1px solid var(--accent-100)}
.card .body{padding:18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .title{font-family:var(--font-display);font-weight:600;font-size:1rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
.card .spec{font-size:.86rem;color:var(--ink);font-weight:500}
.card .rating{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--ink-2);font-weight:600}
.card .rating .st{color:#FBBC04;letter-spacing:.5px}
.card .rating .ct{color:var(--muted);font-weight:500}
.card .warr{font-size:.76rem;color:var(--accent-deep);font-weight:600;display:flex;align-items:center;gap:.35rem;margin-top:2px}
.card .foot{margin-top:auto;padding-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .price{font-family:var(--font-display);font-size:1.32rem;font-weight:700;letter-spacing:-.02em}
.card .priceblock{display:flex;flex-direction:column;gap:1px}
.card .was{font-size:.78rem;color:var(--muted);text-decoration:line-through;text-decoration-color:var(--line-2)}
.card .nowrow{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}
.card .save{font-family:var(--font-body);font-size:.7rem;font-weight:700;color:var(--accent-deep);background:var(--accent-50);border:1px solid var(--accent-100);border-radius:999px;padding:.08rem .42rem}
.feature .fwas{text-decoration:line-through;text-decoration-color:oklch(60% 0.02 250);color:oklch(74% 0.02 250);font-size:.9rem;margin-right:.1rem}
.card .add{width:42px;height:42px;border-radius:var(--r-sm);background:var(--accent);color:#fff;display:grid;place-items:center;transition:.2s var(--ease);flex:none}
.card .add:hover{background:var(--accent-deep);transform:translateY(-1px)}
.row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.tabs{display:flex;gap:9px;margin-bottom:26px;flex-wrap:wrap}
.tab{font-family:var(--font-body);font-weight:600;font-size:.92rem;padding:.62rem 1.35rem;border-radius:999px;border:1px solid var(--line-2);background:#fff;color:var(--ink-2);cursor:pointer;transition:.18s var(--ease)}
.tab:hover{border-color:var(--accent);color:var(--accent-deep)}
.tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
/* bento product showcase (Vercel-inspired, restrained) */
.bento{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:236px;gap:16px}
.tile{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--paper-2);display:flex;align-items:center;justify-content:center;transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.tile img{max-width:72%;max-height:72%;object-fit:contain;mix-blend-mode:multiply;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.tile:hover{border-color:var(--accent-100);box-shadow:var(--shadow-lg)}
.tile:hover img{transform:scale(1.06)}
.tile .chip{position:absolute;top:14px;left:14px;font-size:.72rem;font-weight:700;padding:.26rem .6rem;border-radius:999px;background:var(--surface);color:var(--accent-deep);border:1px solid var(--accent-100)}
.tile .label{position:absolute;left:14px;right:14px;bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.tile .label .nm{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.46rem .85rem;font-size:.83rem;font-weight:600;box-shadow:var(--shadow-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tile .label .pr{background:var(--accent);color:#fff;border-radius:999px;padding:.46rem .8rem;font-size:.83rem;font-weight:700;box-shadow:0 6px 16px oklch(61% 0.19 255/.34);white-space:nowrap;flex:none}
.tile.feat{grid-column:span 2;grid-row:span 2}
.tile.feat img{max-width:62%;max-height:70%}
@media(max-width:880px){.bento{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:200px}.tile.feat{grid-column:span 2;grid-row:span 1}}
@media(max-width:520px){.bento{grid-template-columns:1fr}.tile.feat{grid-column:span 1;grid-row:span 1}}

/* featured deals — asymmetric */
.deals{display:grid;grid-template-columns:1.15fr 2fr;gap:20px}
.feature{position:relative;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(160deg,var(--ink),oklch(34% 0.04 258));color:#fff;padding:32px;display:flex;flex-direction:column;justify-content:space-between;min-height:380px}
.feature .fglow{position:absolute;right:-20%;top:-10%;width:80%;height:80%;background:radial-gradient(circle,var(--accent),transparent 65%);opacity:.5;filter:blur(10px)}
.feature>*{position:relative;z-index:1}
.feature h3{font-size:1.75rem;color:#fff;font-weight:700}
.feature p{color:oklch(85% 0.02 250);margin:.6rem 0 0;font-size:.95rem;max-width:24ch}
.feature img{margin:14px 0;border-radius:var(--r);max-height:160px;width:auto;align-self:center;mix-blend-mode:normal}
.feature .fprice{display:flex;align-items:baseline;gap:.6rem;margin-bottom:14px}
.feature .fprice b{font-family:var(--font-display);font-size:1.7rem}
.feature .fprice span{font-size:.85rem;color:oklch(80% 0.02 250)}
.deals .mini{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}

/* how it works */
.how{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.how .step .n{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;position:relative}
.step .n{font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--accent-deep);width:34px;height:34px;border-radius:9px;background:var(--accent-50);display:grid;place-items:center;margin-bottom:16px}
.step h4{font-family:var(--font-display);font-size:1.12rem;font-weight:600;margin-bottom:8px}
.step p{color:var(--ink-2);font-size:.92rem;margin:0}
/* explainer + accordion */
.explainer{display:grid;grid-template-columns:1.1fr .9fr;gap:52px;align-items:start}
.explainer .lead{font-size:1.12rem;color:var(--ink-2);margin:0 0 22px;max-width:46ch;line-height:1.6}
.acc details{border-top:1px solid var(--line-2)}
.acc details:last-child{border-bottom:1px solid var(--line-2)}
.acc summary{font-family:var(--font-display);font-weight:600;font-size:1.05rem;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:1.5rem;line-height:1;color:var(--accent-deep);font-weight:400;flex:none}
.acc details[open] summary::after{content:"–"}
.acc details p{margin:-2px 0 18px;color:var(--ink-2);font-size:.96rem;line-height:1.65;max-width:52ch}
.exp-img{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.exp-img img{width:100%;aspect-ratio:4/5;object-fit:cover}
@media(max-width:860px){.explainer{grid-template-columns:1fr;gap:28px}}

/* repair band */
.repair{background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:clamp(32px,4vw,52px);display:grid;grid-template-columns:1.25fr 1fr;gap:36px;align-items:center;margin:var(--space) 0;overflow:hidden}
.repair h2{font-size:clamp(1.7rem,3vw,2.4rem);color:#fff;font-weight:700}
.repair p{color:oklch(82% 0.02 250);margin:.9rem 0 0;font-size:1.05rem;max-width:38ch}
.repair-visual{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg)}
.repair-visual img{width:100%;aspect-ratio:4/3;object-fit:cover}

/* why */
.why .wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:52px;align-items:center}
.why h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;margin:.6rem 0 1.4rem}
.why ul{list-style:none;margin:0;padding:0;display:grid;gap:18px}
.why li{display:flex;gap:.85rem;align-items:flex-start;font-size:1rem;color:var(--ink-2)}
.why li b{color:var(--ink)}
.why .tk{flex:none;width:26px;height:26px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center}
.why-visual{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.why-visual img{width:100%;aspect-ratio:5/4;object-fit:cover}
/* privat & företag duo */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.duo-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;background:#fff;display:flex;flex-direction:column}
.duo-card h3{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin-bottom:22px}
.duo-card ul{list-style:none;margin:0 0 26px;padding:0;display:grid;gap:14px;flex:1}
.duo-card li{display:flex;gap:.7rem;align-items:flex-start;font-size:.98rem;color:var(--ink-2)}
.duo-card .tk{flex:none;width:22px;height:22px;border-radius:7px;background:var(--accent-50);color:var(--accent-deep);display:grid;place-items:center}
.duo-card.dark{background:linear-gradient(160deg,var(--ink),oklch(34% 0.04 258));border-color:transparent;color:#fff}
.duo-card.dark h3{color:#fff}
.duo-card.dark li{color:oklch(87% 0.02 250)}
.duo-card.dark .tk{background:oklch(100% 0 0/.15);color:#fff}
@media(max-width:780px){.duo{grid-template-columns:1fr}}

/* footer */
footer{background:var(--paper-2);border-top:1px solid var(--line);padding:56px 0 28px;font-size:.9rem;color:var(--muted)}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:32px}
footer h5{font-family:var(--font-display);margin:0 0 14px;font-size:.95rem;color:var(--ink);font-weight:600}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
footer a:hover{color:var(--accent-deep)}
.pay{display:flex;gap:8px;align-items:center;margin-top:14px}
.pay span{font-size:.74rem;font-weight:700;letter-spacing:.02em;background:#fff;border:1px solid var(--line);border-radius:7px;padding:.32rem .55rem;color:var(--ink-2)}
.fbar{margin-top:40px;border-top:1px solid var(--line);padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.fbar b{font-family:var(--font-display);color:var(--accent-deep);font-weight:600}

.reviews{background:linear-gradient(180deg,#fff,var(--paper-2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.rv-head{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:34px;flex-wrap:wrap}
.rv-score{display:flex;align-items:center;gap:18px}
.rv-num{font-family:var(--font-display);font-size:3.2rem;font-weight:700;line-height:.9;color:var(--ink)}
.rv-stars{color:#FBBC04;font-size:1.15rem;letter-spacing:2px}
.rv-sub{font-size:.93rem;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.rv-glogo{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:var(--ink-2)}
.rv-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.rv-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;gap:13px;box-shadow:var(--shadow-sm)}
.rv-card .s{color:#FBBC04;letter-spacing:1px;font-size:.95rem}
.rv-card p{margin:0;font-size:.96rem;color:var(--ink-2);line-height:1.55;flex:1}
.rv-card .who{display:flex;align-items:center;gap:11px}
.rv-card .av{width:36px;height:36px;border-radius:50%;background:var(--accent-50);color:var(--accent-deep);display:grid;place-items:center;font-weight:700;font-size:.9rem;font-family:var(--font-display);flex:none}
.rv-card .who b{font-size:.88rem;font-weight:600}
.rv-card .who small{display:block;color:var(--muted);font-size:.74rem}
@media(max-width:980px){.rv-grid{grid-template-columns:1fr}}
@media(max-width:980px){
  .hero .wrap,.why .wrap,.repair{grid-template-columns:1fr}
  .strip .wrap{grid-template-columns:repeat(2,1fr);gap:18px}
  .cats{grid-template-columns:repeat(3,minmax(0,1fr))}
  .row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .deals{grid-template-columns:1fr}
  .deals .mini{grid-template-columns:repeat(2,minmax(0,1fr))}
  .steps{grid-template-columns:1fr}
  .nav nav,.search{display:none}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .cats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .row,.deals .mini{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
}
/* shop / product archive */
.crumb{font-size:.85rem;color:var(--muted);padding:22px 0 4px}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--accent-deep)}
.shop-head{padding-bottom:14px}
.shop-h1{font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.3rem);font-weight:800;letter-spacing:-.02em}
.shop-desc{color:var(--muted);margin-top:.5rem;max-width:62ch;font-size:1rem}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:6px 0 22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.shop-toolbar .res{color:var(--muted);font-size:.92rem}
.woocommerce-ordering select,.shop-toolbar select{border:1px solid var(--line-2);border-radius:999px;padding:.55rem 1rem;font-family:var(--font-body);font-size:.9rem;background:var(--surface);color:var(--ink);cursor:pointer}
.shop-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.shop-empty{color:var(--muted);padding:40px 0}
.shop-pager{display:flex;justify-content:center;margin-top:40px}
.shop-pager .page-numbers{list-style:none;display:flex;gap:8px;padding:0;margin:0;flex-wrap:wrap}
.shop-pager .page-numbers li{list-style:none}
.shop-pager .page-numbers a,.shop-pager .page-numbers span{min-width:42px;height:42px;padding:0 12px;border-radius:var(--r-sm);border:1px solid var(--line);display:grid;place-items:center;font-size:.9rem;font-weight:600;background:var(--surface);color:var(--ink)}
.shop-pager .page-numbers .current{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff;border-color:transparent}
.shop-pager .page-numbers a:hover{border-color:var(--accent);color:var(--accent-deep)}
@media(max-width:880px){.shop-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.shop-grid{grid-template-columns:1fr}}
/* single product */
.pdwrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:14px 0 56px;align-items:start}
.gallery .main{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper-2);aspect-ratio:4/3;display:grid;place-items:center;padding:36px;position:relative}
.gallery .main img{max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}
.thumb{border:1px solid var(--line);border-radius:8px;background:var(--paper-2);aspect-ratio:1;display:grid;place-items:center;padding:8px;cursor:pointer;transition:.15s}
.thumb.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.thumb img{max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.pd-info h1{font-family:var(--font-display);font-size:clamp(1.6rem,2.6vw,2.15rem);font-weight:800;line-height:1.15}
.pd-rating{color:#FBBC04;font-size:.95rem;margin:12px 0 10px}
.pd-rating span{color:var(--muted);font-size:.85rem;margin-left:.3rem}
.pd-info .price{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--ink);margin:6px 0}
.pd-info .price del{color:var(--muted);font-size:1rem;font-weight:500;margin-right:.5rem;opacity:.8}
.pd-info .price ins{text-decoration:none}
.pd-vat{color:var(--muted);font-size:.82rem;margin-bottom:6px}
form.cart{display:flex;gap:12px;align-items:center;margin:18px 0;flex-wrap:wrap}
form.cart .quantity input{width:74px;height:52px;border:1.5px solid var(--line-2);border-radius:999px;text-align:center;font-family:var(--font-body);font-size:1rem;background:var(--surface);color:var(--ink)}
.single_add_to_cart_button{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#fff;font-weight:700;font-family:var(--font-display);font-size:1rem;padding:1rem 2.2rem;border-radius:999px;border:0;cursor:pointer;box-shadow:0 8px 20px oklch(61% 0.19 255/.36);transition:.2s var(--ease)}
.single_add_to_cart_button:hover{filter:brightness(1.06);transform:translateY(-1px)}
.pd-trust{display:grid;gap:11px;margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.pd-trust .t{display:flex;gap:.65rem;align-items:center;font-size:.9rem;color:var(--ink-2)}
.pd-trust .t svg{color:var(--accent-deep);flex:none}
.pd-trust .t b{color:var(--ink)}
.pd-specs{padding:8px 0 48px}
.pd-specs h2{font-family:var(--font-display);font-size:1.3rem;font-weight:800;margin:0 0 16px}
.spectable{display:grid;grid-template-columns:1fr 1fr;gap:0 48px}
.spectable .r{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.spectable .k{color:var(--muted)}.spectable .v{font-weight:600}
.pd-desc{padding:0 0 48px;max-width:70ch;color:var(--ink-2);line-height:1.7}
@media(max-width:860px){.pdwrap{grid-template-columns:1fr;gap:28px}.spectable{grid-template-columns:1fr}}
/* custom shop filter (own solution, replaces WooFilter Pro) */
.shop-layout{display:grid;grid-template-columns:248px minmax(0,1fr);gap:32px;align-items:start}
.shop-main .shop-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.tfr-filter{position:sticky;top:92px;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;padding:6px 18px 18px}
.tfr-filter .filter-top{display:flex;align-items:center;justify-content:space-between;padding:14px 0 6px;border-bottom:1px solid var(--line);margin-bottom:6px}
.tfr-filter h3{font-family:var(--font-display);font-size:1.05rem;font-weight:800;letter-spacing:-.02em}
.tfr-filter .filter-reset{font-size:.82rem;font-weight:600;color:var(--accent-deep)}
.tfr-filter .filter-reset:hover{text-decoration:underline}
.facet{border-bottom:1px solid var(--line)}
.facet summary{font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:14px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.facet summary::-webkit-details-marker{display:none}
.facet summary::after{content:"+";font-size:1.25rem;line-height:1;color:var(--accent-deep);font-weight:400}
.facet[open] summary::after{content:"–"}
.facet-opts{display:grid;gap:2px;padding:2px 0 14px;max-height:240px;overflow:auto}
.opt{display:flex;align-items:center;gap:.55rem;font-size:.88rem;color:var(--ink-2);padding:.34rem .4rem;border-radius:var(--r-sm);cursor:pointer;transition:.12s}
.opt:hover{background:var(--paper-2)}
.opt input{accent-color:var(--accent);width:16px;height:16px;flex:none;margin:0}
.opt .nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.opt.on .nm{color:var(--ink);font-weight:600}
.opt .ct{font-size:.74rem;color:var(--muted);background:var(--paper-2);border-radius:999px;padding:.05rem .42rem;flex:none}
.facet-price{display:flex;align-items:center;gap:.5rem;padding:4px 0 14px}
.facet-price input{width:100%;min-width:0;border:1px solid var(--line-2);border-radius:var(--r-sm);padding:.55rem .65rem;font-family:var(--font-body);font-size:.9rem;background:var(--surface);color:var(--ink)}
.facet-price span{color:var(--muted)}
.filter-go{width:100%;justify-content:center;margin-top:16px}
@media(max-width:860px){
  .shop-layout{grid-template-columns:1fr;gap:18px}
  .tfr-filter{position:static}
  .shop-main .shop-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:520px){.shop-main .shop-grid{grid-template-columns:1fr}}
/* live search (own solution, replaces FiboSearch) */
.search{position:relative}
.search svg{flex:none}
.search input[type=search]{flex:1;min-width:0;border:0;background:transparent;font-family:var(--font-body);font-size:.92rem;color:var(--ink);outline:none;padding:0}
.search input[type=search]::placeholder{color:var(--muted)}
.search input[type=search]::-webkit-search-cancel-button{cursor:pointer}
.search-results{position:absolute;top:calc(100% + 10px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:6px;z-index:60;max-height:70vh;overflow:auto}
.sr-item{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:var(--r-sm);transition:.12s}
.sr-item:hover{background:var(--paper-2)}
.sr-img{width:46px;height:46px;flex:none;background:var(--paper-2);border-radius:8px;display:grid;place-items:center;padding:5px}
.sr-img img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.sr-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.sr-title{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--ink);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sr-price{font-size:.84rem;font-weight:700;color:var(--accent-deep)}
.sr-price del{color:var(--muted);font-weight:500;margin-right:.3rem}
.sr-price ins{text-decoration:none}
.sr-all{display:block;text-align:center;padding:11px;margin-top:4px;border-top:1px solid var(--line);font-weight:600;font-size:.88rem;color:var(--accent-deep)}
.sr-all:hover{background:var(--paper-2)}
.sr-empty{padding:18px 12px;color:var(--muted);font-size:.9rem;text-align:center}
/* single product — ported blocks (Liknande, FAQ, B2B) */
.pd-related{padding:8px 0 16px;border-top:1px solid var(--line);margin-top:8px}
.pd-related .sec-head{margin-bottom:24px}
.pd-extra{padding:8px 0 56px}
.pd-extra h2{font-family:var(--font-display);font-size:1.4rem;font-weight:800;letter-spacing:-.02em;margin:28px 0 16px}
.pd-extra details{border-top:1px solid var(--line-2)}
.pd-extra details:last-of-type{border-bottom:1px solid var(--line-2)}
.pd-extra summary{font-family:var(--font-display);font-weight:600;font-size:1.02rem;padding:16px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.pd-extra summary::-webkit-details-marker{display:none}
.pd-extra summary::after{content:"+";font-size:1.4rem;line-height:1;color:var(--accent-deep);font-weight:400;flex:none}
.pd-extra details[open] summary::after{content:"–"}
.pd-extra details p{margin:-2px 0 16px;color:var(--ink-2);line-height:1.65;max-width:70ch}
/* one-click add-to-cart in product cards */
.card .added_to_cart{display:none !important}
.card .add.loading{opacity:.55;pointer-events:none}
.card .add.loading::after,.card .add.loading::before{display:none !important}
.card .add.added{background:var(--accent-deep)}
/* product upgrade options ("Uppgradera din produkt") — parent-theme feature, restyled for the redesign */
.teknikfix-optional-product-heading{font-family:var(--font-display);font-size:1.02rem;font-weight:800;letter-spacing:-.02em;margin:22px 0 12px;color:var(--ink);display:flex;align-items:center;gap:.5rem}
.teknikfix-optional-product-heading::before{content:"";width:18px;height:18px;flex:none;background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23%34%39%37%64%66%66' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2l2.4 7.4H22l-6 4.6 2.3 7.4L12 17.3 5.7 21.4 8 14 2 9.4h7.6z'/%3E%3C/svg%3E")}
.teknikfix-optional-product-wrapper{display:grid;gap:14px;margin:0 0 6px;padding:18px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper-2)}
.teknikfix-optional-product-item{display:grid;gap:6px}
.teknikfix-optional-product-title{font-size:.84rem;font-weight:700;color:var(--ink-2)}
.teknikfix-upgrade-select{width:100%;border:1.5px solid var(--line-2);border-radius:999px;padding:.8rem 2.6rem .8rem 1.1rem;font-family:var(--font-body);font-size:.92rem;color:var(--ink);background-color:#fff;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:15px;transition:.15s}
.teknikfix-upgrade-select:hover{border-color:var(--line-2)}
.teknikfix-upgrade-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px oklch(61% 0.19 255/.15)}
/* ===== product page — impeccable polish (right-column hierarchy + buy block) ===== */
.pdwrap{gap:56px}
.pd-info{display:flex;flex-direction:column}
.pd-info h1{font-size:clamp(1.7rem,2.8vw,2.25rem);line-height:1.13;margin:0}
.pd-info .pd-rating{margin:14px 0 0}
.pd-info > p.price{display:none}                /* duplicate static price; live price lives in the form */
.pd-info > .pd-vat{margin:6px 0 0}
.pd-info > p.stock{margin:16px 0 0;font-weight:600;font-size:.9rem;color:var(--accent-deep)}
/* buy area: live price -> configure -> qty+buy -> omnibus */
.pd-info form.cart{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin:24px 0 0;padding:26px 0 4px;border-top:1px solid var(--line)}
.pd-info form.cart > *{flex:0 0 100%;margin:0}
.pd-info form.cart .teknikfix-price-wrapper{order:1}
.pd-info form.cart .teknikfix-optional-product-heading{order:2;margin:4px 0 0}
.pd-info form.cart .teknikfix-optional-product-wrapper{order:3}
.pd-info form.cart .quantity{order:4;flex:0 0 auto}
.pd-info form.cart .single_add_to_cart_button{order:4;flex:1 1 auto;width:auto;min-width:220px;justify-content:center;padding:1.1rem 2rem;font-size:1.05rem}
.pd-info form.cart .lp30-wrapper{order:5;font-size:.8rem;color:var(--muted)}
/* live price anchor */
.teknikfix-price-wrapper .teknikfix-regular-price{display:flex;flex-wrap:wrap;align-items:baseline;gap:.3rem .7rem}
.teknikfix-price-wrapper .teknikfix-regular-price > .woocommerce-Price-amount{font-family:var(--font-display);font-size:clamp(2rem,3.3vw,2.55rem);font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.teknikfix-ordinary-price-label-wrapper{display:inline-flex;gap:.3rem;align-items:baseline;font-size:.92rem;color:var(--muted)}
.teknikfix-ordinary-price-label-wrapper .woocommerce-Price-amount{text-decoration:line-through;font-weight:500}
/* qty + spec polish */
.pd-info form.cart .quantity input{height:56px;width:88px;border-radius:999px}
.pd-trust{margin-top:26px}
.spectable .r{padding:13px 0}
.spectable .v{font-variant-numeric:tabular-nums}
/* homepage deals tabs — only active panel shows */
.deal-panel[hidden]{display:none}
/* header dropdown nav */
.nav nav .navi{position:relative;display:inline-flex;align-items:center;align-self:stretch}
.nav nav .navi>a{display:inline-flex;align-items:center;gap:.32rem}
.nav nav .navi.has-drop>a::after{content:"";width:7px;height:7px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg);margin-top:-3px;opacity:.55;transition:.18s}
.nav nav .navi.has-drop:hover>a::after{opacity:1}
.nav nav .drop{position:absolute;top:100%;left:-12px;min-width:232px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:8px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease,visibility .16s;z-index:60}
.nav nav .navi:hover .drop,.nav nav .navi:focus-within .drop{opacity:1;visibility:visible;transform:none}
.nav nav .drop a{padding:.6rem .8rem;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--ink-2);white-space:nowrap}
.nav nav .drop a:hover{background:var(--paper-2);color:var(--accent-deep)}
/* category/shop SEO description — below the grid, readable prose */
.shop-seo{max-width:75ch;margin:8px auto 0;padding:38px 0 8px;border-top:1px solid var(--line);color:var(--ink-2);line-height:1.7;font-size:1rem}
.shop-seo h1,.shop-seo h2{font-family:var(--font-display);font-size:1.45rem;font-weight:800;letter-spacing:-.02em;margin:1.6em 0 .5em;color:var(--ink)}
.shop-seo h3{font-family:var(--font-display);font-size:1.12rem;font-weight:700;margin:1.4em 0 .4em;color:var(--ink)}
.shop-seo p{margin:0 0 1em}
.shop-seo ul,.shop-seo ol{margin:0 0 1em;padding-left:1.3em}.shop-seo li{margin:.3em 0}
.shop-seo a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}
/* mobile menu + hamburger */
.nav-toggle{display:none;align-items:center;justify-content:center;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px;margin:0 4px 0 -6px}
.tfr-mobile-menu{position:fixed;inset:0;z-index:1100}
.mm-overlay{position:absolute;inset:0;background:rgba(15,23,42,.45)}
.mm-panel{position:absolute;top:0;left:0;height:100%;width:min(360px,86vw);background:#fff;display:flex;flex-direction:column;box-shadow:20px 0 60px rgba(15,23,42,.22);animation:mmSlide .26s cubic-bezier(.22,.61,.36,1);overflow-y:auto}
@keyframes mmSlide{from{transform:translateX(-100%)}to{transform:none}}
.mm-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line,#e5e9f0)}
.mm-x{border:0;background:none;font-size:1.9rem;line-height:1;color:var(--muted,#6b7280);cursor:pointer;padding:0 4px}
.mm-search{display:flex;align-items:center;gap:.5rem;margin:14px 18px 6px;background:var(--paper-2,#f6f8fc);border:1px solid var(--line-2,#d8dfe9);border-radius:999px;padding:.72rem 1rem;color:var(--muted,#6b7280)}
.mm-search input{flex:1;min-width:0;border:0;background:transparent;font-family:var(--font-body,sans-serif);font-size:.95rem;color:var(--ink,#1F2937);outline:none}
.mm-nav{display:flex;flex-direction:column;padding:6px 12px 10px}
.mm-nav>a,.mm-nav summary{padding:.9rem 8px;font-family:var(--font-display,sans-serif);font-weight:600;font-size:1rem;color:var(--ink,#1F2937);text-decoration:none;border-bottom:1px solid var(--line,#eef1f6);cursor:pointer;list-style:none;display:block}
.mm-nav summary::-webkit-details-marker{display:none}
.mm-nav summary::after{content:"+";float:right;color:var(--accent-deep,#1f6fe5);font-weight:400;font-size:1.35rem;line-height:1}
.mm-nav details[open]>summary::after{content:"\2013"}
.mm-nav details a{padding:.6rem 8px .6rem 20px;font-size:.92rem;font-weight:500;color:var(--ink-2,#44506a);text-decoration:none;display:block}
.mm-nav details a:hover{color:var(--accent-deep,#1f6fe5)}
.mm-foot{margin-top:auto;padding:18px;border-top:1px solid var(--line,#e5e9f0);display:flex;flex-direction:column;gap:4px;font-size:.9rem;color:var(--muted,#6b7280)}
.mm-foot a{color:var(--accent-deep,#1f6fe5);font-weight:700;text-decoration:none;font-size:1.1rem}
@media(max-width:980px){.nav-toggle{display:inline-flex}}
/* mobile filter toggle */
.filter-toggle{display:none;align-items:center;gap:.5rem;width:100%;justify-content:center;background:#fff;border:1.5px solid var(--line-2);border-radius:999px;padding:.85rem 1rem;font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--ink);cursor:pointer;margin-bottom:18px}
@media(max-width:860px){.filter-toggle{display:inline-flex}.tfr-filter{display:none}.tfr-filter.open{display:block;margin-bottom:18px}}
