:root{
  --g:#16855A; --g-h:#0F6E4A; --g-d:#0C5C3E; --g-deep:#064B33; --g-darkest:#03301F;
  --g-l:#ECF7F1; --g-tint:#D0EBDB;
  --a:#F5B935;
  --ink:#0B1426; --ink-soft:#1E2A3B;
  --mu:#5E6A7A; --mu-l:#94A0AE;
  --br:#E3E8EE; --br-soft:#EDF1F5;
  --bg:#FAFBFC; --w:#fff;
  --err:#DC2626; --err-bg:#FEF2F2;
  --shadow-sm:0 1px 2px rgba(11,20,38,.04);
  --shadow:0 2px 12px rgba(11,20,38,.06);
  --shadow-lg:0 12px 40px rgba(11,20,38,.10);
  --radius:14px; --radius-lg:20px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;}
button{font-family:inherit;}
a{color:inherit;}
img,svg{display:block;max-width:100%;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:999;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--br-soft);height:64px;display:flex;align-items:center;padding:0 1.5rem;}
.nav-logo{font-size:1.25rem;font-weight:900;color:var(--ink);text-decoration:none;letter-spacing:-.02em;margin-right:2.5rem;flex-shrink:0;}
.nav-logo b{color:var(--g);}
.nav-links{display:flex;align-items:center;gap:.15rem;flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.nav-links::-webkit-scrollbar{display:none;}
.nav-links a{padding:.5rem .85rem;border-radius:8px;font-size:.82rem;font-weight:600;color:var(--mu);text-decoration:none;white-space:nowrap;cursor:pointer;transition:color .15s,background .15s;border:none;background:none;font-family:inherit;}
.nav-links a:hover{color:var(--ink);background:var(--br-soft);}
.nav-links a.active{color:var(--g);background:var(--g-l);}
.nav-actions{display:flex;align-items:center;gap:.6rem;margin-left:auto;flex-shrink:0;}
.nav-login{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.05rem;color:var(--mu);font-size:.82rem;font-weight:600;text-decoration:none;transition:color .15s;}
.nav-login:hover{color:var(--ink);}
.nav-login svg{opacity:.6;}
.nav-cta{background:var(--g);color:#fff;padding:.55rem 1.25rem;border-radius:10px;font-size:.83rem;font-weight:700;text-decoration:none;border:none;cursor:pointer;font-family:inherit;transition:background .15s,transform .15s;}
.nav-cta:hover{background:var(--g-h);transform:translateY(-1px);}

/* ── LAYOUT ── */
.wrap{padding-top:64px;min-height:100vh;}
.page{display:none;min-height:calc(100vh - 64px);}
.page.active{display:block;animation:fadeIn .25s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.inner{max-width:1140px;margin:0 auto;padding:4rem 1.5rem;}
.inner-narrow{max-width:780px;margin:0 auto;padding:4rem 1.5rem;}

/* ── HEADERS ── */
.page-header{margin-bottom:3rem;max-width:680px;}
.chip{display:inline-block;background:var(--g-l);color:var(--g);font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .85rem;border-radius:100px;margin-bottom:.9rem;}
h1.page-h{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:800;letter-spacing:-.025em;line-height:1.15;margin-bottom:.7rem;}
.page-sub{font-size:1rem;color:var(--mu);line-height:1.65;}
.section-title{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;letter-spacing:-.025em;margin-bottom:.6rem;line-height:1.2;}
.section-sub{font-size:.95rem;color:var(--mu);line-height:1.65;max-width:580px;}

/* ── HERO ── */
.hero{background:radial-gradient(1200px 600px at 80% -10%,rgba(31,168,110,.18),transparent 60%),linear-gradient(165deg,var(--g-darkest) 0%,var(--g-deep) 45%,var(--g-d) 100%);color:#fff;min-height:calc(100vh - 64px);position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:32px 32px;opacity:.4;pointer-events:none;}
.hero-inner{max-width:1140px;margin:0 auto;padding:5rem 1.5rem 4rem;display:grid;grid-template-columns:1fr 440px;gap:4rem;align-items:center;position:relative;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:.4rem 1rem;font-size:.78rem;font-weight:600;margin-bottom:1.4rem;}
.hero-eyebrow .stars{color:var(--a);letter-spacing:1px;}
.hero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:900;letter-spacing:-.03em;line-height:1.1;margin-bottom:1.1rem;}
.hero h1 em{font-style:normal;color:var(--g-tint);}
.hero-lead{font-size:clamp(.95rem,1.6vw,1.1rem);color:rgba(255,255,255,.82);line-height:1.65;margin-bottom:2.2rem;max-width:530px;}
.hero-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:2.8rem;}
.btn-primary{background:#fff;color:var(--g-d);padding:.85rem 1.6rem;border-radius:10px;font-weight:700;font-size:.92rem;text-decoration:none;border:none;cursor:pointer;font-family:inherit;transition:transform .15s,box-shadow .15s;display:inline-flex;align-items:center;gap:.4rem;}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.18);}
.btn-ghost{border:1.5px solid rgba(255,255,255,.35);color:#fff;padding:.85rem 1.4rem;border-radius:10px;font-weight:600;font-size:.92rem;text-decoration:none;background:none;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s;}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55);}
.hero-stats{display:flex;gap:2.5rem;flex-wrap:wrap;}
.hs-val{font-size:1.7rem;font-weight:900;letter-spacing:-.02em;line-height:1;}
.hs-lbl{font-size:.75rem;color:rgba(255,255,255,.65);margin-top:.4rem;}
.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(8px);position:relative;}
.hero-card::before{content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);}
.hc-tag{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--g-tint);margin-bottom:.7rem;}
.hc-title{font-size:1.5rem;font-weight:800;margin-bottom:.5rem;letter-spacing:-.02em;}
.hc-sub{font-size:.85rem;color:rgba(255,255,255,.7);margin-bottom:1.4rem;line-height:1.55;}
.hc-amount{font-size:2.4rem;font-weight:900;margin-bottom:.15rem;letter-spacing:-.025em;background:linear-gradient(180deg,#fff,var(--g-tint));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hc-meta{font-size:.78rem;color:rgba(255,255,255,.55);margin-bottom:1.4rem;}
.hc-feats{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.2rem;}
.hc-feat{display:flex;gap:.6rem;font-size:.86rem;align-items:flex-start;}
.hc-feat svg{flex-shrink:0;margin-top:2px;}
.hc-footnote{font-size:.7rem;color:rgba(255,255,255,.45);padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);}

/* ── TRUST STRIP ── */
.trust-strip{background:#fff;border-bottom:1px solid var(--br-soft);padding:1.5rem 0;}
.trust-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;}

/* Lead-capture-block på paket-sida */
.lead-capture{margin-top:2.5rem;background:linear-gradient(135deg,var(--g-l),#fff);border:1.5px solid var(--g-tint);border-radius:14px;padding:1.4rem 1.6rem;}
.lead-capture-inner{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;}
.lead-capture-icon{font-size:2rem;flex-shrink:0;}
.lead-capture-text{flex:1;min-width:240px;}
.lead-capture-title{font-size:1.05rem;font-weight:800;color:var(--ink);margin-bottom:.3rem;letter-spacing:-.01em;}
.lead-capture-sub{font-size:.85rem;color:var(--mu);line-height:1.5;}
.lead-capture-btn{background:#fff;border:2px solid var(--g);color:var(--g);font-weight:800;font-size:.92rem;padding:.7rem 1.4rem;border-radius:100px;cursor:pointer;font-family:inherit;transition:all .15s;flex-shrink:0;white-space:nowrap;}
.lead-capture-btn:hover{background:var(--g);color:#fff;}

/* Trustpilot-widget */
.tp-section{background:linear-gradient(180deg,#FAFBFC,#fff);padding:3.5rem 1.5rem;border-bottom:1px solid var(--br-soft);}
.tp-inner{max-width:1100px;margin:0 auto;}
.tp-head{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:2rem;gap:.4rem;}
.tp-logo-wrap{display:flex;align-items:center;gap:.6rem;font-size:1.4rem;font-weight:800;color:var(--ink);}
.tp-stars{color:#00B67A;font-size:1.6rem;letter-spacing:2px;}
.tp-rating-big{font-weight:900;color:var(--ink);}
.tp-divider{color:var(--mu);font-weight:300;}
.tp-trustpilot-name{color:#00B67A;font-weight:700;font-size:1.1rem;}
.tp-trustpilot-name::before{content:"";display:inline-block;width:16px;height:16px;background:#00B67A;border-radius:3px;margin-right:.3rem;vertical-align:-2px;}
.tp-meta{font-size:.88rem;color:var(--mu);}
.tp-reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.1rem;margin-bottom:1.5rem;}
.tp-review{background:#fff;border:1px solid var(--br-soft);border-radius:14px;padding:1.3rem 1.4rem;box-shadow:0 1px 3px rgba(0,0,0,.03);transition:transform .15s,box-shadow .15s;}
.tp-review:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06);}
.tp-review-stars{color:#00B67A;font-size:1.05rem;letter-spacing:1.5px;margin-bottom:.5rem;}
.tp-review-text{font-size:.92rem;line-height:1.55;color:var(--ink);font-style:italic;margin-bottom:.7rem;}
.tp-review-by{font-size:.78rem;color:var(--mu);font-weight:600;}
.tp-cta{display:block;text-align:center;font-size:.88rem;font-weight:700;color:var(--g);text-decoration:none;padding:.6rem;transition:color .15s;}
.tp-cta:hover{color:var(--g-d);text-decoration:underline;}
@media(max-width:680px){.tp-section{padding:2.4rem 1rem;}.tp-logo-wrap{font-size:1.15rem;}.tp-stars{font-size:1.3rem;}}
.trust-item{display:flex;align-items:center;gap:.55rem;color:var(--mu);font-size:.83rem;font-weight:600;}
.trust-item svg{color:var(--g);flex-shrink:0;}

/* ── GRIDS ── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem;}

/* ── CARDS ── */
.card{background:#fff;border:1px solid var(--br);border-radius:var(--radius);padding:1.6rem;transition:box-shadow .25s,transform .25s,border-color .25s;}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--g-tint);}
.card-icon{width:42px;height:42px;border-radius:10px;background:var(--g-l);color:var(--g);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;}
.card-title{font-size:1rem;font-weight:700;margin-bottom:.35rem;letter-spacing:-.01em;}
.card-amount{font-size:1.15rem;font-weight:800;color:var(--g);margin-bottom:.45rem;}
.card-desc{font-size:.85rem;color:var(--mu);line-height:1.65;}
.card-list{list-style:none;font-size:.82rem;color:var(--mu);line-height:2;margin-top:.6rem;}
.card-list li::before{content:"✓ ";color:var(--g);font-weight:700;}

/* ── STEPS ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-bottom:3rem;}
.step{background:#fff;border:1px solid var(--br);border-radius:var(--radius);padding:1.7rem;position:relative;}
.snum{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;font-size:.85rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;box-shadow:0 4px 12px rgba(22,133,90,.25);}
.step h3{font-size:1rem;font-weight:700;margin-bottom:.4rem;letter-spacing:-.01em;}
.step p{font-size:.85rem;color:var(--mu);line-height:1.65;}

/* ── BINDNINGSTID-VÄLJARE ── */
.term-selector{display:flex;justify-content:center;margin-bottom:2.5rem;}
.term-toggle{display:inline-flex;background:#fff;border:1px solid var(--br);border-radius:100px;padding:5px;gap:2px;box-shadow:var(--shadow-sm);}
.term-toggle button{padding:.6rem 1.3rem;border-radius:100px;border:none;background:none;color:var(--mu);font-size:.82rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;position:relative;}
.term-toggle button:hover:not(.active){color:var(--ink);}
.term-toggle button.active{background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;box-shadow:0 2px 8px rgba(22,133,90,.25);}
.term-toggle button .savings{display:block;font-size:.65rem;font-weight:600;margin-top:.1rem;opacity:.85;}

/* ── PAKET-KORT ── */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-bottom:1.5rem;}
.pkg{background:#fff;border:1.5px solid var(--br);border-radius:var(--radius-lg);padding:1.8rem;position:relative;transition:box-shadow .25s,border-color .25s,transform .25s;display:flex;flex-direction:column;}
.pkg:hover{box-shadow:var(--shadow);}
.pkg.hot{border-color:var(--g);box-shadow:0 0 0 4px rgba(22,133,90,.08),var(--shadow);}
.pkg.hot:hover{transform:translateY(-3px);}
.pkg-pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;font-size:.68rem;font-weight:700;padding:.3rem 1rem;border-radius:100px;white-space:nowrap;letter-spacing:.05em;text-transform:uppercase;}
.pkg-tag{font-size:.7rem;color:var(--mu);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem;}
.pkg-name{font-size:1.1rem;font-weight:800;margin-bottom:.7rem;letter-spacing:-.01em;}
.pkg-pw{display:flex;align-items:baseline;gap:.3rem;margin-bottom:.2rem;}
.pkg-price{font-size:2.4rem;font-weight:900;color:var(--ink);letter-spacing:-.025em;transition:color .2s;}
.pkg-mo{font-size:.82rem;color:var(--mu);}
.pkg-orig{font-size:.78rem;color:var(--mu);text-decoration:line-through;min-height:1.2em;margin-bottom:.6rem;}
.pkg-orig.hidden{visibility:hidden;}
.pkg-meta{font-size:.78rem;color:var(--mu);margin-bottom:.7rem;}
.pkg-div{height:1px;background:var(--br);margin:1rem 0 1.2rem;}
.pkg-feats{list-style:none;font-size:.84rem;line-height:1.9;margin-bottom:1.4rem;color:var(--ink-soft);flex:1;}
.pkg-feats li{display:flex;gap:.5rem;align-items:flex-start;padding:.1rem 0;}
.pkg-feats li::before{content:"✓";color:var(--g);font-weight:800;flex-shrink:0;}
.pkg-feats li.n{color:var(--mu-l);}
.pkg-feats li.n::before{content:"–";color:var(--mu-l);}

/* Private ID toggle på paketkort */
.addon-row{margin:.4rem 0 1.2rem;padding:.85rem 1rem;background:linear-gradient(135deg,#FFF9EB,#FFFCF5);border:1px solid #FFE5A8;border-radius:10px;display:flex;align-items:center;gap:.7rem;cursor:pointer;transition:all .2s;}
.addon-row:hover{border-color:#FFCD5C;background:linear-gradient(135deg,#FFF4D9,#FFFAEC);}
.addon-row.active{background:linear-gradient(135deg,var(--g-l),#fff);border-color:var(--g);}
.addon-checkbox{width:20px;height:20px;border:2px solid var(--mu-l);border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;transition:all .15s;}
.addon-row.active .addon-checkbox{background:var(--g);border-color:var(--g);color:#fff;}
.addon-checkbox svg{opacity:0;transition:opacity .15s;}
.addon-row.active .addon-checkbox svg{opacity:1;}
.addon-text{flex:1;font-size:.8rem;}
.addon-name{font-weight:700;color:var(--ink);display:flex;align-items:center;gap:.4rem;}
.addon-badge{font-size:.6rem;font-weight:800;color:#92400E;background:#FFE5A8;padding:1px 6px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em;}
.addon-row.active .addon-badge{color:var(--g-deep);background:var(--g-tint);}
.addon-desc{font-size:.72rem;color:var(--mu);margin-top:.1rem;}
.addon-price{font-size:.85rem;font-weight:800;color:var(--g);}

.pkg-btn{display:block;width:100%;text-align:center;padding:.85rem;border-radius:10px;font-size:.88rem;font-weight:700;border:1.5px solid var(--br);color:var(--ink);background:#fff;cursor:pointer;font-family:inherit;transition:all .15s;}
.pkg-btn:hover{border-color:var(--g);color:var(--g);background:var(--g-l);}
.pkg.hot .pkg-btn{background:var(--g);color:#fff;border-color:var(--g);}
.pkg.hot .pkg-btn:hover{background:var(--g-h);border-color:var(--g-h);}

.pkg-sec-label{font-size:.78rem;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.08em;margin:3rem 0 1.2rem;padding-top:2.5rem;border-top:1px solid var(--br);}

/* ── STORA PAKETKORT (TVÅ SIDA VID SIDA) ── */
.big-pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem;}
.big-pkg{background:#fff;border:1.5px solid var(--br);border-radius:var(--radius-lg);padding:2rem;position:relative;transition:box-shadow .25s,border-color .25s,transform .25s;display:flex;flex-direction:column;}
.big-pkg:hover{box-shadow:var(--shadow);}
.big-pkg.hot{border-color:var(--g);box-shadow:0 0 0 4px rgba(22,133,90,.08),var(--shadow);}
.big-pkg.hot:hover{transform:translateY(-3px);}
.big-pkg-pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;font-size:.68rem;font-weight:700;padding:.3rem 1rem;border-radius:100px;white-space:nowrap;letter-spacing:.05em;text-transform:uppercase;}
.big-pkg-head{margin-bottom:1.3rem;}
.big-pkg-eyebrow{font-size:.72rem;color:var(--mu);font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;}
.big-pkg.hot .big-pkg-eyebrow{color:var(--g);}
.big-pkg-title{font-size:1.15rem;font-weight:800;letter-spacing:-.015em;line-height:1.3;color:var(--ink);}

/* Typ-toggle inuti kortet */
.type-toggle{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;background:var(--bg);border:1px solid var(--br);border-radius:12px;padding:4px;margin-bottom:1.2rem;}
.type-toggle button{padding:.7rem .4rem;border-radius:9px;border:none;background:transparent;cursor:pointer;font-family:inherit;transition:all .15s;text-align:center;}
.type-toggle button:hover:not(.active){background:#fff;}
.type-toggle button.active{background:#fff;box-shadow:0 1px 4px rgba(11,20,38,.08);}
.type-label{font-size:.85rem;font-weight:700;color:var(--ink);}
.type-meta{font-size:.7rem;color:var(--mu);margin-top:.15rem;}
.type-toggle button.active .type-label{color:var(--ink);}
.type-toggle button:not(.active) .type-label{color:var(--mu);}

/* Pris-rad */
.big-pkg-price-row{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.5rem;flex-wrap:wrap;}
.big-pkg-price{display:flex;align-items:baseline;gap:.3rem;}
.big-pkg-price > span:first-child{font-size:2.6rem;font-weight:900;color:var(--ink);letter-spacing:-.025em;line-height:1;}
.big-pkg-mo{font-size:.88rem;color:var(--mu);}
.big-pkg-orig{font-size:.78rem;color:var(--mu);text-decoration:line-through;}
.big-pkg-orig.hidden{display:none;}

/* ── ADDRESS AUTOCOMPLETE ── */
.autocomplete-wrap{position:relative;}
.autocomplete-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--br);border-radius:10px;box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;z-index:50;display:none;}
.autocomplete-list.open{display:block;}
.autocomplete-item{padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid var(--br-soft);font-size:.88rem;transition:background .1s;}
.autocomplete-item:last-child{border-bottom:none;}
.autocomplete-item:hover,.autocomplete-item.focused{background:var(--g-l);}
.autocomplete-item-main{font-weight:600;color:var(--ink);}
.autocomplete-item-sub{font-size:.78rem;color:var(--mu);margin-top:.15rem;}
.autocomplete-loading{padding:.8rem 1rem;font-size:.82rem;color:var(--mu);text-align:center;}
.autocomplete-empty{padding:.8rem 1rem;font-size:.82rem;color:var(--mu);text-align:center;font-style:italic;}

/* ── JÄMFÖR TABELL ── */
.diff-tbl{background:#fff;border:1px solid var(--br);border-radius:var(--radius-lg);overflow:hidden;width:100%;}
.diff-tbl table{width:100%;border-collapse:collapse;}
.diff-tbl th{background:var(--bg);padding:1rem 1.5rem;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mu);text-align:left;border-bottom:1px solid var(--br);}
.diff-tbl th:not(:first-child){text-align:center;}
.diff-tbl td{padding:1rem 1.5rem;border-bottom:1px solid var(--br-soft);font-size:.88rem;}
.diff-tbl tr:last-child td{border:none;}
.diff-tbl td:not(:first-child){text-align:center;font-weight:700;}
.fn{font-weight:600;color:var(--ink);}
.fsub{font-size:.76rem;color:var(--mu);font-weight:400;margin-top:.15rem;}
.ty{color:var(--g);font-size:1.1rem;}
.tn{color:#D1D5DB;font-size:1.1rem;}

/* Konkurrentjämförelse — framhäv SmartID-kolumnen */
.compare-tbl th.us{background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;font-size:.85rem;text-transform:none;letter-spacing:0;font-weight:800;}
.compare-tbl td.us{background:var(--g-l);font-weight:700;color:var(--g-deep);}
.compare-tbl td.us .ty{color:var(--g);}
.compare-tbl th{font-size:.74rem;}
.compare-tbl td{font-size:.83rem;}
@media(max-width:700px){
  .compare-tbl{font-size:.78rem;}
  .compare-tbl th,.compare-tbl td{padding:.55rem .5rem;}
  .compare-tbl .fsub{display:none;}
}

.hint-box{background:var(--g-l);border:1px solid var(--g-tint);border-radius:var(--radius);padding:1.1rem 1.4rem;font-size:.9rem;color:var(--g-deep);display:flex;gap:.7rem;align-items:flex-start;margin-bottom:2rem;}
.hint-box svg{flex-shrink:0;color:var(--g);margin-top:2px;}

/* ── PRIVATE ID-SEKTION ── */
.privateid-hero{background:linear-gradient(135deg,#FFF9EB,#FFFCF5);border:1px solid #FFE5A8;border-radius:var(--radius-lg);padding:3rem;margin-bottom:3rem;display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:center;}
.privateid-hero .badge{display:inline-flex;align-items:center;gap:.4rem;background:#FFE5A8;color:#78350F;font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .9rem;border-radius:100px;margin-bottom:1rem;}
.privateid-hero h2{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:800;margin-bottom:.7rem;letter-spacing:-.02em;line-height:1.2;}
.privateid-hero p{color:var(--mu);font-size:.95rem;line-height:1.7;margin-bottom:1.3rem;}
.pid-sites{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.4rem;}
.pid-site{background:#fff;border:1px solid #FFE5A8;border-radius:8px;padding:.3rem .7rem;font-size:.75rem;font-weight:700;color:var(--ink-soft);}
.pid-visual{background:#fff;border:1px solid #FFE5A8;border-radius:14px;padding:1.4rem;}
.pid-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--br-soft);font-size:.85rem;}
.pid-row:last-child{border-bottom:none;}
.pid-row-name{font-weight:600;color:var(--ink);}
.pid-status{font-size:.72rem;font-weight:700;padding:.15rem .55rem;border-radius:100px;}
.pid-status.removed{background:var(--g-l);color:var(--g);}
.pid-status.pending{background:#FEF3C7;color:#92400E;}
.pid-status.found{background:#FEE2E2;color:#991B1B;}

/* ── SUPPORT ── */
.sup-grid{display:grid;grid-template-columns:1fr 360px;gap:2rem;}
.sup-form{background:#fff;border:1px solid var(--br);border-radius:var(--radius-lg);padding:2rem;}
.cbox{background:#fff;border:1px solid var(--br);border-radius:var(--radius);padding:1.2rem;display:flex;gap:.9rem;}
.cbox.urg{border-color:var(--g);background:var(--g-l);}
.cbi{width:38px;height:38px;border-radius:10px;background:var(--g-l);color:var(--g);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cbox.urg .cbi{background:#fff;}
.cbv{font-size:.92rem;font-weight:700;color:var(--ink);}
.cbl{font-size:.78rem;color:var(--mu);margin-top:.15rem;line-height:1.5;}
.portal-lnk{display:inline-block;margin-top:.5rem;font-size:.8rem;font-weight:700;color:var(--g);text-decoration:none;}
.portal-lnk:hover{text-decoration:underline;}

/* ── FORMS ── */
.fg{display:flex;flex-direction:column;gap:.35rem;}
.fg label{font-size:.78rem;font-weight:700;color:var(--ink-soft);}
.fg input,.fg select,.fg textarea{padding:.75rem 1rem;border:1.5px solid var(--br);border-radius:10px;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;background:#fff;color:var(--ink);width:100%;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(22,133,90,.12);}
.fg input.invalid,.fg select.invalid{border-color:var(--err);box-shadow:0 0 0 3px rgba(220,38,38,.08);}
.fg input.valid{border-color:var(--g);}
.fg textarea{min-height:100px;resize:vertical;}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.fgrid .full{grid-column:1/-1;}
.fhint{font-size:.72rem;color:var(--mu);margin-top:.1rem;}
.ferror{font-size:.74rem;color:var(--err);margin-top:.2rem;font-weight:600;display:none;}
.ferror.show{display:block;}
.fsub-btn{background:var(--g);color:#fff;padding:.85rem 1.8rem;border:none;border-radius:10px;font-size:.92rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s,transform .15s;}
.fsub-btn:hover:not(:disabled){background:var(--g-h);transform:translateY(-1px);}
.fsub-btn:disabled{opacity:.55;cursor:not-allowed;}
.flegal{font-size:.74rem;color:var(--mu);margin-top:.3rem;line-height:1.55;}
.flegal a{color:var(--g);}
.fsuccess{display:none;background:var(--g-l);border:1px solid var(--g-tint);border-radius:10px;padding:.85rem 1.1rem;margin-top:.6rem;color:var(--g-deep);font-weight:600;font-size:.88rem;}

/* honeypot - osynlig för människor, synlig för bots */
.honeypot{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none;}

/* ── AI-CHAT CTA på support-sidan ── */
.ai-chat-cta{
  display:flex;align-items:center;gap:1.2rem;
  background:linear-gradient(135deg,var(--g-d),var(--g-deep));color:#fff;
  border-radius:var(--radius-lg);padding:1.4rem 1.6rem;
  margin-bottom:2rem;position:relative;overflow:hidden;
}
.ai-chat-cta::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);
  background-size:24px 24px;pointer-events:none;opacity:.5;
}
.ai-chat-cta-icon{
  width:48px;height:48px;border-radius:12px;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;position:relative;
}
.ai-chat-cta-text{flex:1;position:relative;}
.ai-chat-cta-title{font-size:1.05rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.2rem;}
.ai-chat-cta-sub{font-size:.85rem;color:rgba(255,255,255,.8);line-height:1.5;}
.ai-chat-cta-btn{
  background:#fff;color:var(--g-d);
  border:none;border-radius:10px;
  padding:.75rem 1.3rem;font-size:.88rem;font-weight:700;
  cursor:pointer;font-family:inherit;flex-shrink:0;
  position:relative;transition:transform .15s,box-shadow .15s;
}
.ai-chat-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.2);}
@media(max-width:640px){
  .ai-chat-cta{flex-direction:column;align-items:flex-start;text-align:left;}
  .ai-chat-cta-btn{width:100%;}
}

/* ── TERMS DOC (kompakt typografi för villkor/sekretess) ── */
.terms-doc{font-size:.85rem;line-height:1.65;color:var(--ink-soft);}
.terms-doc h3{font-size:.95rem;font-weight:800;margin:1.4rem 0 .4rem;color:var(--ink);letter-spacing:-.005em;}
.terms-doc h3:first-child{margin-top:0;}
.terms-doc p{margin-bottom:.7rem;}
.terms-doc ul{list-style:disc;margin:.3rem 0 .7rem 1.4rem;padding:0;}
.terms-doc ul li{margin-bottom:.3rem;line-height:1.6;}
.terms-doc b{color:var(--ink);}
.terms-doc a{color:var(--g);}
.terms-doc .terms-foot{margin-top:2.2rem;padding:1.1rem 1.3rem;background:var(--bg);border-radius:10px;font-size:.78rem;color:var(--mu);line-height:1.6;border-left:3px solid var(--g);}

/* ── COOKIE-BANNER ── */
.cookie-banner{
  position:fixed;bottom:24px;left:24px;z-index:8000;
  max-width:380px;background:#fff;
  border:1px solid var(--br);border-radius:14px;
  box-shadow:0 12px 32px rgba(11,20,38,.15);
  padding:1.2rem 1.4rem;
  font-size:.85rem;line-height:1.6;color:var(--ink-soft);
  transform:translateY(20px);opacity:0;pointer-events:none;
  transition:transform .3s ease,opacity .3s ease;
}
.cookie-banner.show{transform:translateY(0);opacity:1;pointer-events:auto;}
.cookie-banner .cb-title{font-weight:800;color:var(--ink);margin-bottom:.4rem;font-size:.92rem;}
.cookie-banner a{color:var(--g);font-weight:600;}
.cookie-banner .cb-actions{display:flex;gap:.5rem;margin-top:.8rem;}
.cookie-banner .cb-ok{background:var(--g);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.82rem;font-weight:700;cursor:pointer;font-family:inherit;flex:1;}
.cookie-banner .cb-ok:hover{background:var(--g-h);}
.cookie-banner .cb-link{background:none;border:1.5px solid var(--br);color:var(--ink);border-radius:8px;padding:.5rem 1rem;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;}
.cookie-banner .cb-link:hover{border-color:var(--g);color:var(--g);}
@media(max-width:540px){
  .cookie-banner{left:12px;right:12px;bottom:12px;max-width:none;}
}

/* ── CHATBOT-WIDGET ── */
.chat-launcher{
  position:fixed;bottom:24px;right:24px;z-index:9000;
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--g),var(--g-d));
  color:#fff;border:none;cursor:pointer;
  box-shadow:0 8px 24px rgba(22,133,90,.35);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,box-shadow .2s;
}
.chat-launcher:hover{transform:scale(1.06);box-shadow:0 12px 32px rgba(22,133,90,.45);}
.chat-launcher .pulse{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(22,133,90,.4);
  animation:chat-pulse 2s infinite;
}
@keyframes chat-pulse{
  0%{transform:scale(1);opacity:.5;}
  100%{transform:scale(1.7);opacity:0;}
}
.chat-launcher.open .pulse{display:none;}

.chat-panel{
  position:fixed;bottom:96px;right:24px;z-index:9001;
  width:380px;max-width:calc(100vw - 32px);height:580px;max-height:calc(100vh - 120px);
  background:#fff;border-radius:18px;
  box-shadow:0 20px 48px rgba(11,20,38,.25);
  display:none;flex-direction:column;overflow:hidden;
  transform:translateY(12px);opacity:0;
  transition:transform .25s ease,opacity .25s ease;
}
.chat-panel.open{display:flex;transform:translateY(0);opacity:1;}
.chat-head{
  background:linear-gradient(135deg,var(--g-d),var(--g-deep));
  color:#fff;padding:1rem 1.2rem;
  display:flex;align-items:center;gap:.7rem;
}
.chat-avatar{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.95rem;flex-shrink:0;
}
.chat-head-text{flex:1;min-width:0;}
.chat-head-name{font-size:.95rem;font-weight:700;letter-spacing:-.01em;}
.chat-head-status{font-size:.72rem;opacity:.8;display:flex;align-items:center;gap:.3rem;margin-top:.1rem;}
.chat-head-status::before{content:"";width:6px;height:6px;border-radius:50%;background:#4ADE80;}
.chat-close{background:none;border:none;color:#fff;cursor:pointer;opacity:.7;padding:.3rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s;}
.chat-close:hover{opacity:1;background:rgba(255,255,255,.1);}

.chat-msgs{
  flex:1;overflow-y:auto;padding:1rem;
  display:flex;flex-direction:column;gap:.7rem;
  background:linear-gradient(180deg,#FAFBFC,#fff);
}
.chat-msg{max-width:85%;padding:.7rem 1rem;border-radius:14px;font-size:.88rem;line-height:1.55;animation:chat-msg-in .2s ease;}
@keyframes chat-msg-in{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}
.chat-msg.bot{background:#fff;color:var(--ink);border:1px solid var(--br-soft);border-radius:14px 14px 14px 4px;align-self:flex-start;box-shadow:0 1px 2px rgba(0,0,0,.03);}
.chat-msg.user{background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;border-radius:14px 14px 4px 14px;align-self:flex-end;}
.chat-msg b{font-weight:700;}
.chat-msg a{color:var(--g);text-decoration:underline;}
.chat-msg.user a{color:#fff;}

/* Chat markdown (bot-meddelanden) — rena, lättlästa "rutor" */
.chat-msg .cm-h{font-size:.92rem;font-weight:800;margin:.5rem 0 .3rem;color:var(--ink);letter-spacing:-.01em;}
.chat-msg h2.cm-h{font-size:1.02rem;}
.chat-msg h3.cm-h{font-size:.94rem;}
.chat-msg h4.cm-h{font-size:.86rem;color:var(--g-d);}
.chat-msg .cm-p{margin:0 0 .35rem;}
.chat-msg .cm-p:last-child{margin-bottom:0;}
.chat-msg .cm-sp{height:.4rem;}
.chat-msg .cm-hr{border:none;border-top:1px dashed var(--br);margin:.6rem 0;}
.chat-msg .cm-ul,.chat-msg .cm-ol{margin:.2rem 0 .4rem 0;padding-left:1.2rem;line-height:1.55;}
.chat-msg .cm-ul li,.chat-msg .cm-ol li{margin-bottom:.2rem;}
.chat-msg .cm-ul li::marker{color:var(--g);}
.chat-msg code{background:var(--bg);padding:1px 5px;border-radius:4px;font-size:.83em;font-family:ui-monospace,Menlo,monospace;color:var(--g-d);}
.chat-msg .cm-link{
  color:var(--g);font-weight:700;text-decoration:none;
  background:var(--g-l);padding:2px 8px;border-radius:6px;
  display:inline-block;margin:1px 0;transition:all .12s;
  border:1px solid transparent;
}
.chat-msg .cm-link:hover{
  background:#fff;border-color:var(--g);text-decoration:none;
}
.chat-msg .cm-table .cm-link{padding:0 4px;font-size:inherit;}

/* Tabell-ruta i chatten — visas som ett kort med rader, ej rå pipe-tabell */
.chat-msg .cm-table-card{
  background:var(--bg);border:1px solid var(--br-soft);
  border-radius:10px;padding:.55rem .15rem .15rem;margin:.5rem 0;
  overflow-x:auto;
}
.chat-msg .cm-table{width:100%;border-collapse:collapse;font-size:.8rem;}
.chat-msg .cm-table th{
  background:transparent;color:var(--mu);font-weight:700;
  text-align:left;padding:.3rem .55rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;
  border-bottom:1px solid var(--br-soft);
}
.chat-msg .cm-table td{
  padding:.4rem .55rem;border-bottom:1px solid var(--br-soft);
  vertical-align:top;
}
.chat-msg .cm-table tbody tr:last-child td{border-bottom:none;}
.chat-msg .cm-table td.cm-th-cell{font-weight:700;color:var(--ink);white-space:nowrap;}
.chat-msg .cm-table td:not(.cm-th-cell){color:var(--g-d);font-variant-numeric:tabular-nums;}

.chat-typing{display:flex;gap:4px;align-items:center;padding:.7rem 1rem;background:#fff;border:1px solid var(--br-soft);border-radius:14px;align-self:flex-start;}
.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--mu-l);animation:typing-bounce 1.2s infinite;}
.chat-typing span:nth-child(2){animation-delay:.15s;}
.chat-typing span:nth-child(3){animation-delay:.3s;}
@keyframes typing-bounce{0%,60%,100%{transform:translateY(0);opacity:.4;}30%{transform:translateY(-4px);opacity:1;}}

.chat-action-card{
  background:linear-gradient(135deg,var(--g-l),#fff);
  border:1px solid var(--g-tint);border-radius:12px;
  padding:.85rem 1rem;margin-top:.4rem;
  font-size:.83rem;color:var(--g-deep);
  display:flex;align-items:center;gap:.6rem;
}
.chat-action-card svg{color:var(--g);flex-shrink:0;}

.chat-quick{
  display:flex;flex-wrap:wrap;gap:.4rem;padding:0 1rem .7rem;
}
.chat-quick-btn{
  background:#fff;border:1.5px solid var(--g-tint);
  color:var(--g-d);font-size:.78rem;font-weight:600;
  padding:.45rem .85rem;border-radius:100px;cursor:pointer;
  font-family:inherit;transition:all .15s;
}
.chat-quick-btn:hover{background:var(--g-l);border-color:var(--g);}

.chat-input-row{
  display:flex;gap:.5rem;padding:.8rem 1rem;
  border-top:1px solid var(--br-soft);background:#fff;
}
.chat-input{
  flex:1;padding:.65rem 1rem;border:1.5px solid var(--br);
  border-radius:100px;font-size:.88rem;font-family:inherit;outline:none;
  transition:border-color .15s,box-shadow .15s;background:#fff;
}
.chat-input:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(22,133,90,.1);}
.chat-send{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;
  border:none;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s;
}
.chat-send:hover:not(:disabled){transform:scale(1.05);}
.chat-send:disabled{opacity:.4;cursor:not-allowed;}

.chat-foot{
  font-size:.68rem;color:var(--mu);text-align:center;
  padding:.5rem;background:var(--bg);border-top:1px solid var(--br-soft);
}
.chat-foot b{color:var(--ink);}

@media(max-width:540px){
  .chat-panel{
    bottom:0;right:0;left:0;top:0;
    width:100vw;height:100vh;max-height:100vh;
    border-radius:0;
  }
  .chat-launcher{bottom:16px;right:16px;}
}

/* ── PRIVATE ID-INFO-IKON i addon-row ── */
.addon-info-btn{
  width:22px;height:22px;border-radius:50%;
  background:#fff;border:1.5px solid #FFE5A8;
  color:#92400E;font-size:.75rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;
  font-family:'Plus Jakarta Sans',sans-serif;
  transition:all .15s;
}
.addon-info-btn:hover{background:#FFE5A8;transform:scale(1.1);}
.addon-row.active .addon-info-btn{border-color:var(--g-tint);color:var(--g-deep);}
.addon-row.active .addon-info-btn:hover{background:var(--g-tint);}

/* ── PRIVATE ID-MODAL ── */
.pid-modal-box{background:#fff;border-radius:var(--radius-lg);padding:0;max-width:540px;width:100%;position:relative;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;}
.pid-modal-head{padding:1.8rem 2rem 1rem;background:linear-gradient(135deg,#FFF9EB,#FFFCF5);border-bottom:1px solid #FFE5A8;position:relative;}
.pid-modal-close{position:absolute;top:.9rem;right:.9rem;background:none;border:none;font-size:1rem;cursor:pointer;color:var(--mu-l);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.pid-modal-close:hover{background:rgba(255,229,168,.5);color:var(--ink);}
.pid-modal-badge{display:inline-flex;align-items:center;gap:.4rem;background:#FFE5A8;color:#78350F;font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .9rem;border-radius:100px;margin-bottom:.7rem;}
.pid-modal-title{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;line-height:1.3;color:var(--ink);}
.pid-modal-body{padding:1.5rem 2rem;overflow-y:auto;flex:1;}
.pid-points{list-style:none;display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.2rem;}
.pid-points li{display:flex;gap:.7rem;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);line-height:1.55;}
.pid-points li svg{flex-shrink:0;margin-top:2px;color:#92400E;}
.pid-points li b{color:var(--ink);}
.pid-more-toggle{background:none;border:none;color:var(--g);font-weight:700;font-size:.88rem;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.3rem;padding:0;margin-bottom:.5rem;}
.pid-more-toggle:hover{text-decoration:underline;}
.pid-more-toggle svg{transition:transform .2s;}
.pid-more-toggle.open svg{transform:rotate(180deg);}
.pid-more-content{display:none;padding-top:1rem;border-top:1px solid var(--br-soft);margin-top:.5rem;}
.pid-more-content.open{display:block;}
.pid-more-content h4{font-size:.85rem;font-weight:800;margin-bottom:.4rem;letter-spacing:-.01em;}
.pid-more-content p{font-size:.85rem;color:var(--mu);line-height:1.7;margin-bottom:1rem;}
.pid-more-sites{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;}
.pid-modal-foot{padding:1.2rem 2rem 1.6rem;border-top:1px solid var(--br-soft);background:#FAFBFC;display:flex;flex-direction:column;gap:.5rem;}
.pid-modal-foot .add-btn{background:linear-gradient(135deg,#92400E,#78350F);color:#fff;border:none;border-radius:10px;padding:.85rem;font-size:.92rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.pid-modal-foot .add-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(146,64,14,.3);}
.pid-modal-foot .add-btn.active{background:linear-gradient(135deg,var(--g),var(--g-d));}
.pid-modal-foot .close-link{background:none;border:none;color:var(--mu);font-size:.83rem;cursor:pointer;font-family:inherit;text-decoration:underline;}
.pid-modal-foot .close-link:hover{color:var(--ink);}

/* ── TESTIMONIALS ── */
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;}
.tm{background:#fff;border:1px solid var(--br);border-radius:var(--radius);padding:1.6rem;}
.tms{color:var(--a);font-size:.95rem;margin-bottom:.7rem;letter-spacing:1px;}
.tmq{font-size:.9rem;line-height:1.65;color:var(--ink);margin-bottom:.9rem;}
.tmw{font-size:.85rem;font-weight:700;}
.tml{font-size:.76rem;color:var(--mu);}

.tp-band{background:linear-gradient(135deg,#fff,var(--g-l));border:1px solid var(--g-tint);border-radius:var(--radius);padding:1.2rem 1.8rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;}
.tp-stars{color:var(--a);letter-spacing:1px;font-size:1.1rem;}
.tp-lnk{font-size:.85rem;font-weight:700;color:var(--g);text-decoration:none;}
.tp-lnk:hover{text-decoration:underline;}

/* ── FAQ ── */
.faq-wrap{max-width:780px;}
.faq-item{border-bottom:1px solid var(--br);}
.faq-q{width:100%;text-align:left;padding:1.1rem 0;background:none;border:none;cursor:pointer;font-size:.95rem;font-weight:600;display:flex;justify-content:space-between;gap:1rem;font-family:inherit;color:var(--ink);}
.faq-arr{color:var(--mu-l);transition:transform .2s;flex-shrink:0;font-size:.85rem;}
.faq-q.open .faq-arr{transform:rotate(180deg);color:var(--g);}
.faq-a{font-size:.88rem;line-height:1.75;padding:0 0 1.2rem;display:none;color:var(--mu);}
.faq-a.open{display:block;}

/* ── B2B ── */
.b2b-assist{background:linear-gradient(135deg,var(--g-l),#fff);border:1px solid var(--g-tint);border-radius:var(--radius);padding:1.7rem;margin-bottom:1.5rem;}
.b2b-assist-title{font-size:.78rem;font-weight:700;color:var(--g);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.9rem;}
.b2b-al{list-style:none;font-size:.88rem;line-height:2.1;color:var(--g-deep);display:grid;grid-template-columns:1fr 1fr;gap:.2rem;}
.b2b-al li::before{content:"✓  ";color:var(--g);font-weight:800;}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(11,20,38,.6);backdrop-filter:blur(4px);z-index:10000;display:none;align-items:center;justify-content:center;padding:1rem;overflow-y:auto;}
.modal-overlay.open{display:flex;animation:fadeIn .2s;}
.modal-box{background:#fff;border-radius:var(--radius-lg);padding:0;max-width:520px;width:100%;position:relative;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;}
.modal-head{padding:1.5rem 2rem 1rem;border-bottom:1px solid var(--br-soft);position:relative;}
.modal-close{position:absolute;top:.9rem;right:.9rem;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--mu-l);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.modal-close:hover{background:var(--br-soft);color:var(--ink);}
.modal-title{font-size:1.15rem;font-weight:800;letter-spacing:-.01em;}
.modal-sub{font-size:.83rem;color:var(--mu);margin-top:.2rem;}
.modal-body{padding:1.5rem 2rem;overflow-y:auto;flex:1;}
.modal-foot{padding:1rem 2rem 1.5rem;border-top:1px solid var(--br-soft);display:flex;gap:.7rem;justify-content:space-between;align-items:center;background:#FAFBFC;}

/* Stepper */
.stepper{display:flex;align-items:center;gap:.4rem;padding:0 2rem 1rem;}
.stepper-dot{width:22px;height:22px;border-radius:50%;background:var(--br);color:var(--mu);font-size:.7rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;}
.stepper-dot.done{background:var(--g);color:#fff;}
.stepper-dot.active{background:var(--g);color:#fff;box-shadow:0 0 0 4px rgba(22,133,90,.15);}
.stepper-line{flex:1;height:2px;background:var(--br);transition:background .2s;}
.stepper-line.done{background:var(--g);}

.step-content{display:none;}
.step-content.active{display:block;animation:fadeIn .2s ease;}

/* Order summary */
.summary{background:var(--g-l);border:1px solid var(--g-tint);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:1.2rem;}
.summary-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.88rem;padding:.35rem 0;}
.summary-row.divider{border-top:1px solid var(--g-tint);margin-top:.4rem;padding-top:.7rem;font-weight:800;font-size:.95rem;}
.summary-label{color:var(--ink-soft);}
.summary-val{font-weight:700;color:var(--ink);}
.summary-meta{font-size:.78rem;color:var(--mu);padding:.2rem 0;}

.tooltip{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;color:var(--g);font-weight:700;cursor:help;position:relative;border-bottom:1px dashed var(--g-tint);padding-bottom:1px;}
.tooltip-content{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:.74rem;font-weight:500;padding:.6rem .85rem;border-radius:8px;width:240px;line-height:1.5;opacity:0;pointer-events:none;transition:opacity .15s;z-index:1;}
.tooltip-content::after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border:5px solid transparent;border-top-color:var(--ink);}
.tooltip:hover .tooltip-content{opacity:1;}

.invoice-info{background:#F0F9FF;border:1px solid #BAE6FD;border-radius:10px;padding:1rem 1.2rem;font-size:.85rem;color:#075985;line-height:1.6;}
.invoice-info b{color:#0C4A6E;}

/* ── BANKID UI ── */
.bankid-wrap{display:flex;flex-direction:column;gap:1.2rem;}
.bankid-launchers{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;}
.bankid-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.2rem .8rem;background:#fff;border:1.5px solid var(--br);border-radius:12px;cursor:pointer;font-family:inherit;transition:all .15s;text-decoration:none;color:var(--ink);}
.bankid-btn:hover{border-color:#1E3A8A;background:#F0F4FF;}
.bankid-btn svg{color:#1E3A8A;}
.bankid-btn-label{font-size:.85rem;font-weight:700;text-align:center;line-height:1.3;}
.bankid-btn-sub{font-size:.72rem;color:var(--mu);text-align:center;}
.bankid-status{background:#F0F4FF;border:1px solid #C7D2FE;border-radius:12px;padding:1.5rem;text-align:center;}
.bankid-status .spinner{width:36px;height:36px;border:3px solid #C7D2FE;border-top-color:#1E3A8A;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem;}
@keyframes spin{to{transform:rotate(360deg);}}
.bankid-status-text{font-size:.92rem;font-weight:700;color:#1E3A8A;margin-bottom:.3rem;}
.bankid-status-sub{font-size:.8rem;color:var(--mu);line-height:1.5;}
.bankid-qr-wrap{background:#fff;padding:1rem;border-radius:12px;display:inline-block;margin:.5rem 0;border:1px solid var(--br);}
.bankid-qr{width:200px;height:200px;background:#fff;display:flex;align-items:center;justify-content:center;}
.bankid-cancel{background:none;border:1px solid #FECACA;color:var(--err);padding:.5rem 1rem;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;margin-top:.7rem;font-family:inherit;}
.bankid-cancel:hover{background:var(--err-bg);}
.bankid-agreement{background:var(--bg);border:1px solid var(--br);border-radius:10px;padding:.9rem 1.1rem;font-size:.8rem;color:var(--ink-soft);line-height:1.6;font-style:italic;}
.bankid-agreement b{color:var(--ink);font-style:normal;}

/* ── PROMO ── */
.promo{display:inline-flex;align-items:center;gap:.5rem;background:var(--g-l);border:1px solid var(--g-tint);border-radius:100px;padding:.45rem 1rem;font-size:.82rem;font-weight:600;color:var(--g-deep);margin-bottom:1.5rem;}

/* ── FOOTER ── */
footer{background:#0A1119;color:rgba(255,255,255,.55);padding:4rem 1.5rem 2rem;}
.footer-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;}
.fl-logo{font-size:1.4rem;font-weight:900;color:#fff;margin-bottom:.7rem;letter-spacing:-.02em;}
.fl-logo b{color:var(--g);}
.fl-tag{font-size:.85rem;line-height:1.7;max-width:260px;}
.fcol h4{font-size:.78rem;font-weight:700;color:#fff;margin-bottom:1rem;letter-spacing:.05em;text-transform:uppercase;}
.fcol a{display:block;font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none;margin-bottom:.5rem;transition:color .15s;cursor:pointer;}
.fcol a:hover{color:#fff;}
.fbar{max-width:1140px;margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;font-size:.75rem;flex-wrap:wrap;gap:1rem;}

/* ── RESPONSIVE ── */
@media(max-width:1000px){
  .grid-3,.pkg-grid,.steps,.tm-grid{grid-template-columns:1fr 1fr!important;}
  .hero-inner{grid-template-columns:1fr!important;gap:2.5rem;}
  .hero-card{display:none;}
  .privateid-hero{grid-template-columns:1fr!important;padding:2rem;}
  .pid-visual{display:none;}
  .footer-inner{grid-template-columns:1fr 1fr!important;}
  .sup-grid{grid-template-columns:1fr!important;}
  .big-pkg-grid{grid-template-columns:1fr!important;gap:2.5rem;}
}
@media(max-width:640px){
  .grid-3,.grid-2,.pkg-grid,.steps,.tm-grid{grid-template-columns:1fr!important;}
  .fgrid{grid-template-columns:1fr!important;}
  .b2b-al{grid-template-columns:1fr!important;}
  nav{padding:0 1rem;}
  .nav-logo{margin-right:1rem;}
  .nav-login span{display:none;}
  .inner,.inner-narrow{padding:3rem 1rem;}
  .hero-inner{padding:3.5rem 1rem 3rem;}
  .term-toggle{flex-wrap:wrap;justify-content:center;}
  .modal-head,.modal-body,.modal-foot{padding-left:1.3rem;padding-right:1.3rem;}
  .stepper{padding:0 1.3rem 1rem;}
}

/* ─── SMARTID VALV ─────────────────────────────────────────────── */
.valv-row {
  background: linear-gradient(135deg, rgba(99,102,241,.06), rgba(168,85,247,.06));
  border-color: rgba(168,85,247,.25) !important;
}
.valv-row.active {
  border-color: #A855F7 !important;
  background: linear-gradient(135deg, rgba(99,102,241,.10), rgba(168,85,247,.10));
}
.valv-row.active .addon-checkbox {
  background: #A855F7;
  border-color: #A855F7;
}
.valv-hero {
  background: linear-gradient(135deg, #F8FAFC 0%, #EDE9FE 100%);
  color: #0B1426;
}
.valv-hero .hero-eyebrow {
  background: rgba(168,85,247,.12);
  border-color: rgba(168,85,247,.32);
  color: #6B21A8;
}
.valv-hero .hero-title { color: #0B1426; }
.valv-hero .hero-sub   { color: #475569; }
.valv-hero .hero-trust { color: #5E6A7A !important; }
.valv-hero .btn-secondary {
  color: #6B21A8;
  border-color: rgba(168,85,247,.32);
  background: rgba(255,255,255,.6);
}
.valv-hero .btn-secondary:hover { background: rgba(255,255,255,.9); }
.benefit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2rem;
}
.benefit-card {
  background: #fff;
  border: 1px solid #E3E8EE;
  border-radius: 14px;
  padding: 1.6rem;
  text-align: center;
}
.benefit-card h3 { font-size: 1.05rem; margin: .5rem 0 .3rem; color: var(--ink); }
.benefit-card p  { font-size: .87rem; color: var(--mu); line-height: 1.5; margin: 0; }
.benefit-icon { font-size: 2.2rem; line-height: 1; }
.faq-item {
  background: #fff; border: 1px solid #E3E8EE; border-radius: 12px;
  margin-bottom: .7rem; padding: 0;
}
.faq-item summary {
  padding: 1rem 1.2rem; font-weight: 700; cursor: pointer;
  list-style: none; color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; float: right; font-weight: 900; color: var(--pr); font-size: 1.3rem; line-height: 1; }
.faq-item[open] summary::after { content: "−"; }
.faq-item p { padding: 0 1.2rem 1rem; margin: 0; color: var(--mu); font-size: .92rem; line-height: 1.6; }
.valv-modal { z-index: 9999; }

/* ── MOBILE STICKY CTA (opt-in per page via .mobile-cta-bar markup) ── */
.mobile-cta-bar{display:none;}
@media(max-width:768px){
  .mobile-cta-bar{
    display:flex;align-items:center;justify-content:center;
    position:fixed;left:0;right:0;bottom:0;z-index:7000;
    height:64px;padding:0 84px 0 16px;
    background:rgba(255,255,255,.97);
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
    border-top:1px solid var(--br);box-shadow:0 -4px 20px rgba(11,20,38,.10);
    text-decoration:none;
  }
  .mobile-cta-bar span{
    display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
    width:100%;max-width:360px;
    background:linear-gradient(135deg,var(--g),var(--g-d));color:#fff;
    font-weight:800;font-size:.95rem;padding:.85rem 1.4rem;border-radius:12px;
    box-shadow:0 4px 14px rgba(22,133,90,.35);
  }
  body:has(.mobile-cta-bar){padding-bottom:74px;}
}
