/* ============================================================
   Tempo Redovisning, designsystem v3
   Typografidriven minimalism: papper, bläck, en röd accent.
   Inga gradienter, inga effekter som inte bär betydelse.
   Konceptet: T-kontot (debet | kredit) genomsyrar märke och form.
   ============================================================ */

:root{
  /* Färg */
  --paper:     #FAF7F2;
  --paper-2:   #F3EDE4;
  --ink:       #1B1612;
  --ink-soft:  #5C534B;
  --muted:     #8E837A;
  --line:      rgba(27,22,18,.14);
  --line-soft: rgba(27,22,18,.08);

  --red:       #DA3A2A;
  --red-deep:  #A8261C;
  --red-tint:  #F9E9E5;

  /* Typografi */
  --sans: 'Schibsted Grotesk', system-ui, -apple-system, sans-serif;
  --mono: 'Spline Sans Mono', ui-monospace, monospace;

  /* Mått */
  --maxw: 1200px;
  --pad: 32px;
  --ease: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:96px; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; line-height:1.06; letter-spacing:-.02em; font-weight:700; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--red); color:#fff; }
:focus-visible{ outline:2.5px solid var(--red); outline-offset:3px; border-radius:3px; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

/* Hoppa till innehåll */
.skip-link{
  position:fixed; top:-60px; left:16px; z-index:200;
  background:var(--ink); color:var(--paper); font-weight:600; font-size:15px;
  padding:12px 18px; border-radius:8px; transition:top .2s ease;
}
.skip-link:focus{ top:14px; }

/* ---- Typografi ---- */
.kicker{
  font-family:var(--mono); font-size:12.5px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft);
}
.kicker .no{ color:var(--red); margin-right:10px; }
.display{
  font-size:clamp(52px, 8vw, 122px);
  font-weight:800; letter-spacing:-.045em; line-height:.95;
}
.h2{ font-size:clamp(34px, 4.4vw, 58px); font-weight:750; letter-spacing:-.035em; line-height:1.02; }
.h3{ font-size:clamp(20px, 1.9vw, 24px); font-weight:650; letter-spacing:-.02em; }
.lead{ font-size:clamp(18px, 1.5vw, 21px); color:var(--ink-soft); line-height:1.55; }

/* Sektionshuvud med nummer + linje */
.sec-head{ padding-top:26px; border-top:1px solid var(--line); }
.sec-head .kicker{ display:block; }
.sec-head .h2{ margin-top:22px; max-width:18ch; }
.sec-head .lead{ margin-top:18px; max-width:640px; }

/* ---- Knappar ---- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-weight:600; font-size:16px;
  padding:15px 27px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; white-space:nowrap;
  transition:background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s var(--ease);
}
.btn .arr{ transition:transform .18s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--red); color:#fff; }
.btn-primary:hover{ background:var(--red-deep); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); }

/* ---- Logotyp: T-kontot ---- */
.logo{ display:inline-flex; align-items:center; gap:13px; }
.logo .mark{ width:34px; height:34px; flex:none; color:var(--ink); }
.logo .mark svg{ width:100%; height:100%; display:block; }
.logo .wm{ display:flex; flex-direction:column; line-height:1; gap:4px; }
.logo .wm .name{ font-weight:800; font-size:21px; letter-spacing:-.03em; }
.logo .wm .desc{ font-family:var(--mono); font-size:9.5px; font-weight:500; letter-spacing:.34em; text-transform:uppercase; color:var(--muted); }
.logo.on-dark{ color:var(--paper); }
.logo.on-dark .mark{ color:var(--paper); }
.logo.on-dark .wm .desc{ color:rgba(250,247,242,.55); }

/* ============================================================
   Header
   ============================================================ */
.site-head{
  position:sticky; top:0; z-index:50;
  background:rgba(250,247,242,.85);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease;
}
.site-head.scrolled{ border-bottom-color:var(--line); }
.site-head .bar{ display:flex; align-items:center; justify-content:space-between; height:80px; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a{
  font-size:15.5px; font-weight:500; color:var(--ink-soft);
  position:relative; padding:6px 0; white-space:nowrap; transition:color .15s;
}
.nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:1px; height:1.5px;
  background:var(--red); transition:right .22s var(--ease);
}
.nav a:hover{ color:var(--ink); }
.nav a:hover::after{ right:0; }
.head-cta{ display:flex; align-items:center; gap:20px; }
.head-phone{ font-family:var(--mono); font-size:14.5px; font-weight:500; color:var(--ink); white-space:nowrap; }
.head-phone:hover{ color:var(--red); }

.menu-btn{
  display:none; width:44px; height:44px; border-radius:10px;
  border:1px solid var(--line); background:transparent;
  align-items:center; justify-content:center; cursor:pointer;
  flex-direction:column; gap:5px; transition:border-color .2s ease;
}
.menu-btn:hover{ border-color:var(--ink); }
.menu-btn .b1, .menu-btn .b2{
  display:block; width:18px; height:1.8px; border-radius:2px; background:var(--ink);
  transition:transform .25s var(--ease);
}
.menu-btn[aria-expanded="true"] .b1{ transform:translateY(3.4px) rotate(45deg); }
.menu-btn[aria-expanded="true"] .b2{ transform:translateY(-3.4px) rotate(-45deg); }

.nav-drawer{
  display:grid; grid-template-rows:0fr; opacity:0;
  border-top:1px solid transparent; background:var(--paper);
  transition:grid-template-rows .3s var(--ease), opacity .25s ease, border-color .25s ease;
}
.nav-drawer.open{ grid-template-rows:1fr; opacity:1; border-top-color:var(--line); }
.nav-drawer .inner{ overflow:hidden; min-height:0; }
.nav-drawer .wrap{ padding-top:12px; padding-bottom:24px; }
.nav-drawer a:not(.btn){ display:block; padding:15px 2px; font-size:19px; font-weight:600; border-bottom:1px solid var(--line-soft); color:var(--ink); }
.nav-drawer .dphone{ font-family:var(--mono); font-size:14.5px; color:var(--muted); padding:16px 2px 4px; }
.nav-drawer .btn{ margin-top:16px; width:100%; justify-content:center; }

/* ============================================================
   Hero
   ============================================================ */
.hero{ padding:104px 0 84px; }
.hero .grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:64px; align-items:center; }
.hero .kicker{ display:block; }
.hero h1{ margin-top:26px; max-width:13ch; }
.hero .lead{ margin-top:30px; max-width:560px; }
.hero .cta{ margin-top:40px; display:flex; gap:14px; flex-wrap:wrap; }
.hero .conn{ margin-top:56px; display:flex; gap:26px; flex-wrap:wrap; align-items:center; }
.hero .conn .lbl{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.hero .conn .it{ display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:13.5px; color:var(--ink); }
.hero .conn .it .d{ width:6px; height:6px; border-radius:50%; background:var(--red); }

/* T-konto-illustrationen: dubbel bokföring som lugn loop.
   Verifikationer bokförs i par (debet, sedan kredit), kontot stäms av
   med dubbelstreck som växer ut från stammen, vilar länge, tonar ut
   och börjar om. En cykel tar 14 s och är stilla större delen av tiden. */
.hero-art{ position:relative; display:flex; justify-content:center; }

/* T-kontot som dokument: statusrad, ram, två kolumner, summor, etiketter */
.tacc{ width:min(100%, 450px); font-family:var(--mono); color:var(--ink); }
.tacc .status{
  display:flex; justify-content:flex-end; align-items:center; gap:9px;
  font-size:10.5px; font-weight:500; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); padding-bottom:14px; min-height:25px;
}
.tacc .status .sdot{ width:6px; height:6px; border-radius:50%; background:var(--red); flex:none; }
.tacc .status .stxt{ white-space:nowrap; }
.tacc .status.working .sdot{ animation:sdot 1.1s ease-in-out infinite; }
@keyframes sdot{ 50%{ opacity:.2; } }

/* Verifikationen: korrekt bokföringsuppställning (Konto | Debet | Kredit) */
.tacc .vhead{
  display:flex; justify-content:space-between; align-items:baseline; gap:12px;
  border-top:3px solid var(--ink);
  padding:15px 0 4px;
  font-size:11px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft);
}
.tacc .vhead .vno{ letter-spacing:.14em; }
.tacc .vhead .vdate{ color:var(--muted); letter-spacing:.08em; }
.tacc .vcols .c{ font-weight:500; }
.tacc .vrow .deb, .tacc .vrow .kre{ font-variant-numeric:tabular-nums; }
.tacc .vcols{
  display:grid; grid-template-columns:1fr 84px 84px; gap:10px;
  padding:13px 0 9px; border-bottom:1px solid var(--line);
  font-size:10.5px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
}
.tacc .num{ text-align:right; }
.tacc .vrow{
  display:grid; grid-template-columns:1fr 84px 84px; gap:10px; align-items:baseline;
  padding:12px 0; min-height:44px;
  border-bottom:1px solid var(--line-soft);
  font-size:13.5px; letter-spacing:.02em;
  transition:color .6s ease, opacity .45s ease;
}
.tacc .vrow .acc{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.tacc .vrow.fresh{ color:var(--red); }
.tacc .vsum{ transition:opacity .45s ease; }
.tacc .vsumrow{
  display:grid; grid-template-columns:1fr 84px 84px; gap:10px;
  padding:14px 0 11px; font-size:13.5px; font-weight:600;
}
.tacc .dbl{ height:5px; border-top:1px solid rgba(27,22,18,.65); border-bottom:1px solid rgba(27,22,18,.65); }
.tacc .fade{ opacity:0 !important; }

/* Huvudboken: ett riktigt T-konto (ETT konto, bara belopp, debet | kredit).
   Kryssbalken och stammen är logotypens T i sin fackmässiga roll. */
.tacc .tkonto{ margin-top:28px; transition:opacity .45s ease; }
.tacc .tk-head{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; padding-bottom:10px; }
.tacc .tk-lbl{ font-size:10.5px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.tacc .tk-title{ font-size:12px; font-weight:600; letter-spacing:.06em; color:var(--ink-soft); }
.tacc .tk-frame{ display:grid; grid-template-columns:1fr 1fr; border-top:3px solid var(--ink); }
.tacc .tk-side{ display:flex; flex-direction:column; gap:8px; padding:11px 16px 13px; }
.tacc .tk-side + .tk-side{ border-left:3px solid var(--ink); }
.tacc .tk-cap{ font-size:10px; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); }
.tacc .tk-amt{
  font-size:13.5px; text-align:right; min-height:19px;
  font-variant-numeric:tabular-nums;
  transition:color .6s ease, opacity .4s ease;
}
.tacc .tk-amt.ib{ color:var(--muted); }
.tacc .tk-amt.fresh{ color:var(--red); }
.tacc .tk-saldo{
  display:flex; justify-content:flex-end; align-items:baseline; gap:12px;
  padding-top:11px; margin-top:2px; border-top:1px solid var(--line);
  font-weight:600; font-size:13.5px;
}

.caret{
  display:inline-block; width:7px; height:12px; background:var(--red);
  vertical-align:-1px; margin-left:2px;
  animation:caret 1.1s ease-in-out infinite;
}
.caret.solid{ animation:none; }
@keyframes caret{ 0%,100%{ opacity:1; } 50%{ opacity:.12; } }

/* Tecknen landar mjukt: mikro-oskärpa och en knapp nedsättning */
.tacc .ch{ display:inline-block; animation:chin .32s var(--ease) both; }
@keyframes chin{
  from{ opacity:0; filter:blur(2px); transform:translateY(-3px); }
  to{ opacity:1; filter:none; transform:none; }
}

/* ============================================================
   Trust-rad
   ============================================================ */
.trust{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust .row{ display:grid; grid-template-columns:repeat(4,1fr); }
.trust .ti{ padding:30px 28px 30px 0; }
.trust .ti + .ti{ border-left:1px solid var(--line-soft); padding-left:28px; }
.trust .ti b{ display:flex; align-items:center; gap:9px; font-size:15px; letter-spacing:-.01em; }
.trust .ti b .d{ width:6px; height:6px; border-radius:50%; background:var(--red); flex:none; }
.trust .ti span{ display:block; font-size:13.5px; color:var(--muted); margin-top:5px; line-height:1.4; }

/* ============================================================
   Sektioner
   ============================================================ */
.section{ padding:110px 0; }

/* ---- Jämförelsen (pedagogik) ---- */
.compare{ margin-top:64px; display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--line); border-radius:18px; overflow:hidden; }
.compare .col{ padding:42px 44px 46px; }
.compare .col.old{ background:var(--paper-2); }
.compare .col.new{ background:var(--ink); color:var(--paper); }
.compare .col h3{ font-size:15px; font-family:var(--mono); font-weight:600; letter-spacing:.14em; text-transform:uppercase; }
.compare .col.old h3{ color:var(--muted); }
.compare .col.new h3{ color:#E89B8E; }
.compare .col ul{ margin-top:26px; display:flex; flex-direction:column; }
.compare .col li{ display:flex; gap:14px; align-items:flex-start; padding:15px 0; font-size:16px; line-height:1.5; }
.compare .col li + li{ border-top:1px solid var(--line-soft); }
.compare .col.new li + li{ border-top-color:rgba(250,247,242,.12); }
.compare .col.old li{ color:var(--ink-soft); }
.compare .col.new li{ color:rgba(250,247,242,.92); }
.compare .col li svg{ width:17px; height:17px; flex:none; margin-top:4px; }
.compare .col.old li svg{ color:var(--red); }
.compare .col.new li svg{ color:#E89B8E; }
.compare-sum{ margin-top:30px; font-size:clamp(19px,2vw,23px); font-weight:650; letter-spacing:-.02em; max-width:30ch; }
.compare-sum .r{ color:var(--red); }

/* ---- Stegen ---- */
.steps{ margin-top:64px; display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); }
.steps .step{ padding:34px 36px 8px 0; }
.steps .step + .step{ border-left:1px solid var(--line-soft); padding-left:36px; }
.steps .no{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--red); letter-spacing:.08em; }
.steps h3{ margin-top:14px; }
.steps p{ margin-top:10px; color:var(--ink-soft); font-size:15.5px; line-height:1.55; }

/* ---- Diagrammet ---- */
.diagram{ margin-top:72px; border:1px solid var(--line); border-radius:18px; padding:44px 40px 36px; }
.diagram .lbl{ text-align:center; font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.diagram .chips{ margin-top:18px; display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.diagram .chip{
  font-family:var(--mono); font-size:13px; color:var(--ink);
  border:1px solid var(--line); border-radius:999px; padding:9px 16px;
  display:inline-flex; align-items:center; gap:8px; background:transparent;
}
.diagram .chip .d{ width:6px; height:6px; border-radius:50%; background:var(--red); }
.diagram .down{ display:flex; justify-content:center; gap:64px; padding:20px 0 6px; color:var(--muted); }
.diagram .down svg{ width:15px; height:26px; }
.diagram .gate{
  margin:10px auto 0; max-width:460px; text-align:center;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--ink-soft);
  border:1px dashed var(--line); border-radius:10px; padding:11px;
}
.diagram .ledger{
  margin:22px auto 0; max-width:560px;
  background:var(--ink); color:var(--paper); border-radius:13px;
  padding:20px 24px; display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.diagram .ledger b{ font-size:17px; letter-spacing:-.01em; }
.diagram .ledger span{ font-family:var(--mono); font-size:12px; color:rgba(250,247,242,.75); display:inline-flex; align-items:center; gap:9px; }
.diagram .ledger .live{ width:6px; height:6px; border-radius:50%; background:var(--red); flex:none; animation:pulse 2.4s ease-out infinite; }
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(218,58,42,.5); }
  70%{ box-shadow:0 0 0 8px rgba(218,58,42,0); }
  100%{ box-shadow:0 0 0 0 rgba(218,58,42,0); }
}
.diagram .audit{
  margin-top:22px; display:flex; justify-content:center; align-items:center; gap:10px;
  font-size:14px; color:var(--ink-soft);
}
.diagram .audit svg{ width:16px; height:16px; color:var(--red); flex:none; }

/* ---- Ingår-listan ---- */
.includes{ margin-top:64px; display:grid; grid-template-columns:repeat(3,1fr); gap:0 44px; }
.includes .it{ border-top:1px solid var(--line); padding:26px 0 30px; }
.includes .it svg{ width:22px; height:22px; color:var(--red); }
.includes .it h3{ font-size:17.5px; margin-top:14px; letter-spacing:-.015em; }
.includes .it p{ margin-top:8px; color:var(--ink-soft); font-size:15px; line-height:1.55; }

/* ---- Byt-sektionen ---- */
.switch{ background:var(--ink); color:var(--paper); }
.switch .sec-head{ border-top-color:rgba(250,247,242,.2); }
.switch .kicker{ color:rgba(250,247,242,.65); }
.switch .lead{ color:rgba(250,247,242,.72); }
.switch .steps{ border-top-color:rgba(250,247,242,.2); }
.switch .steps .step + .step{ border-left-color:rgba(250,247,242,.12); }
.switch .steps .no{ color:#E89B8E; }
.switch .steps p{ color:rgba(250,247,242,.72); }
.switch .from{ margin-top:54px; display:flex; gap:12px 26px; flex-wrap:wrap; align-items:center; }
.switch .from .lbl{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:rgba(250,247,242,.55); }
.switch .from .f{ font-family:var(--mono); font-size:13.5px; color:rgba(250,247,242,.9); }
.switch .btn-ghost{ color:var(--paper); border-color:rgba(250,247,242,.35); }
.switch .btn-ghost:hover{ border-color:var(--paper); }

/* ---- FAQ ---- */
.faq{ margin-top:56px; border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px;
  background:none; border:none; cursor:pointer; text-align:left;
  font-family:var(--sans); font-size:clamp(18px,1.8vw,21px); font-weight:600; letter-spacing:-.015em; color:var(--ink);
  padding:26px 2px;
}
.faq-q .pm{ position:relative; width:18px; height:18px; flex:none; }
.faq-q .pm::before, .faq-q .pm::after{
  content:""; position:absolute; background:var(--red); border-radius:2px;
  transition:transform .25s var(--ease);
}
.faq-q .pm::before{ left:0; right:0; top:8px; height:2px; }
.faq-q .pm::after{ top:0; bottom:0; left:8px; width:2px; }
.faq-item.open .faq-q .pm::after{ transform:scaleY(0); }
.faq-a{
  display:grid; grid-template-rows:0fr; opacity:0;
  transition:grid-template-rows .3s var(--ease), opacity .25s ease;
}
.faq-item.open .faq-a{ grid-template-rows:1fr; opacity:1; }
.faq-a .inner{ overflow:hidden; min-height:0; }
.faq-a p{ padding:0 40px 28px 2px; color:var(--ink-soft); font-size:16.5px; line-height:1.6; max-width:62ch; }

/* ============================================================
   Kontakt
   ============================================================ */
.k-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:72px; align-items:start; margin-top:64px; }
.k-list{ border-top:1px solid var(--line); }
.k-item{ display:flex; justify-content:space-between; align-items:baseline; gap:20px; padding:24px 2px; border-bottom:1px solid var(--line); }
.k-item .lab{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.k-item .val{ text-align:right; }
.k-item .val a{ font-weight:650; font-size:clamp(17px,1.7vw,20px); letter-spacing:-.015em; }
.k-item .val a:hover{ color:var(--red); }
.k-item .val span{ display:block; font-size:13.5px; color:var(--muted); margin-top:3px; }
.k-note{ margin-top:26px; font-size:15px; color:var(--ink-soft); line-height:1.6; max-width:44ch; }

.form{ border:1px solid var(--line); border-radius:18px; padding:40px; }
.form h3{ margin-bottom:6px; }
.form .sub{ color:var(--ink-soft); font-size:15.5px; margin-bottom:28px; }
.field{ margin-bottom:20px; }
.field label{ display:block; font-family:var(--mono); font-size:11.5px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px; }
.field input, .field textarea{
  width:100%; font-family:var(--sans); font-size:16.5px; color:var(--ink);
  padding:13px 2px; border:none; border-bottom:1px solid var(--line); border-radius:0;
  background:transparent;
  transition:border-color .15s ease;
}
.field input::placeholder, .field textarea::placeholder{ color:var(--muted); }
.field input:focus, .field textarea:focus{ outline:none; border-bottom-color:var(--ink); box-shadow:0 1px 0 0 var(--ink); }
.field input.invalid, .field textarea.invalid{ border-bottom-color:var(--red); box-shadow:0 1px 0 0 var(--red); }
.field textarea{ resize:vertical; min-height:110px; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.form .btn{ width:100%; justify-content:center; margin-top:10px; }
.form .note{ font-size:12.5px; color:var(--muted); margin-top:16px; text-align:center; }
.hp{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.ok{
  display:none; align-items:flex-start; gap:11px;
  background:var(--red-tint); border:1px solid #EFC7BF; color:var(--red-deep);
  border-radius:12px; padding:16px 18px; font-weight:600; margin-bottom:24px; font-size:15px;
}
.ok svg{ width:19px; height:19px; flex:none; margin-top:2px; }
.ok.show{ display:flex; }

/* ============================================================
   Footer
   ============================================================ */
.site-foot{ background:var(--ink); color:var(--paper); padding:90px 0 40px; }
.site-foot .big{
  font-size:clamp(64px, 11vw, 168px); font-weight:800; letter-spacing:-.05em; line-height:.9;
  display:flex; align-items:baseline; gap:22px; flex-wrap:wrap;
}
.site-foot .big .desc{ font-family:var(--mono); font-size:clamp(11px,1.2vw,14px); font-weight:500; letter-spacing:.34em; text-transform:uppercase; color:rgba(250,247,242,.5); }
.foot-cols{ margin-top:64px; display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.foot-cols .tagline{ max-width:340px; color:rgba(250,247,242,.65); font-size:15.5px; line-height:1.6; }
.foot-col h4{ font-size:11.5px; font-family:var(--mono); font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:rgba(250,247,242,.5); margin-bottom:16px; }
.foot-col ul{ display:flex; flex-direction:column; gap:10px; font-size:16px; }
.site-foot a{ color:rgba(250,247,242,.8); transition:color .15s; }
.site-foot a:hover{ color:#fff; }
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  margin-top:70px; padding-top:28px; border-top:1px solid rgba(250,247,242,.15);
  font-size:13.5px; color:rgba(250,247,242,.5);
}
.foot-nav{ display:flex; gap:26px; flex-wrap:wrap; font-size:14.5px; }

/* ============================================================
   Scroll-avslöjanden
   ============================================================ */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.07s; }
.reveal.d2{ transition-delay:.14s; }
.reveal.d3{ transition-delay:.21s; }

/* ============================================================
   Responsivt
   ============================================================ */
@media (max-width:1024px){
  .nav, .head-phone{ display:none; }
  .menu-btn{ display:inline-flex; }
}
@media (max-width:980px){
  .hero .grid{ grid-template-columns:1fr; gap:48px; }
  .hero-art{ justify-content:flex-start; }
  .hero-art svg{ width:min(100%, 340px); }
  .trust .row{ grid-template-columns:1fr 1fr; }
  .trust .ti{ padding:24px 24px 24px 0; }
  .trust .ti + .ti{ border-left:none; padding-left:0; }
  .trust .ti:nth-child(even){ border-left:1px solid var(--line-soft); padding-left:24px; }
  .trust .ti:nth-child(n+3){ border-top:1px solid var(--line-soft); }
  .includes{ grid-template-columns:1fr 1fr; }
}
@media (max-width:880px){
  .section{ padding:80px 0; }
  .hero{ padding:72px 0 64px; }
  .compare{ grid-template-columns:1fr; }
  .compare .col{ padding:34px 28px 38px; }
  .steps{ grid-template-columns:1fr; }
  .steps .step{ padding:28px 0 20px; }
  .steps .step + .step{ border-left:none; border-top:1px solid var(--line-soft); padding-left:0; padding-top:28px; }
  .switch .steps .step + .step{ border-top-color:rgba(250,247,242,.12); }
  .k-grid{ grid-template-columns:1fr; gap:48px; }
  .row2{ grid-template-columns:1fr; gap:0; }
  .diagram{ padding:34px 24px 30px; }
  .diagram .down{ gap:44px; }
}
@media (max-width:640px){
  .includes{ grid-template-columns:1fr; }
  .form{ padding:30px 24px; }
  .hero .cta .btn{ width:100%; justify-content:center; }
  /* Verifikationen: tätare kolumner så att kontonamnen aldrig klipps */
  .tacc .vcols, .tacc .vrow, .tacc .vsumrow{ grid-template-columns:1fr 64px 64px; gap:8px; }
  .tacc .vrow, .tacc .vsumrow, .tacc .tk-amt, .tacc .tk-saldo{ font-size:12.5px; }
  .tacc .tk-title{ font-size:11.5px; }
}
@media (max-width:560px){
  .trust .row{ grid-template-columns:1fr; }
  .trust .ti{ padding:20px 0 !important; border-left:none !important; }
  .trust .ti + .ti{ border-top:1px solid var(--line-soft); }
}

/* ============================================================
   Rörelsekänslighet
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .diagram .ledger .live{ animation:none; box-shadow:none; }
  /* Agentvinjetten i T-kontot är medvetet undantagen: den spelar bara på
     besökarens egen interaktion (hover/scroll), är liten till ytan och
     består av toningar och mikrorörelser, inte spatial rörelse. */
}
