/* ============ Storylab — design tokens (teal + taupe + cream) ============ */
/* Anpassad för BÅDE barn och äldre (60–90): stor text, stora knappar, hög kontrast */
:root{
  --teal:#2E617A;
  --deep-teal:#234D61;
  --taupe:#AAA39C;
  --warm-stone:#B5AEA8;
  --soft-ivory:#F7F5F1;
  --paper:#FCFBF8;
  --ink:#2B2A28;
  --ash:#6F6B66;
  --mist:#D8E4E8;
  --night:#171615;
  --moon:#EDE8E1;
  --gold:#C8923A;

  --bg:var(--soft-ivory);
  --surface:var(--paper);
  --surface-2:#F1EEE8;
  --text:var(--ink);
  --text-2:var(--ash);
  --accent:var(--teal);
  --accent-strong:var(--deep-teal);
  --line:#E6E1D9;
  --highlight:var(--mist);

  --r:18px;
  --r-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

.screen[data-theme="dark"]{
  --bg:var(--night);
  --surface:#201F1D;
  --surface-2:#2A2826;
  --text:var(--moon);
  --text-2:#A39E96;
  --accent:#6FA6BE;
  --accent-strong:#8FBED2;
  --line:#34322F;
  --highlight:#27353B;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;margin:0;}
body{
  font-family:"Georgia","Iowan Old Style",serif;
  background:var(--bg);
  color:var(--ink);
  min-height:100dvh;
}

/* I förhandsvisning (bredare skärm) ritas en telefonram runt appen. */
@media (min-width:520px){
  body{
    background:radial-gradient(1200px 700px at 50% -10%, #ece7df 0%, #d9d3c9 60%, #cfc8bd 100%);
    display:flex;align-items:center;justify-content:center;padding:22px 12px;
  }
  .screen{
    width:min(420px,100vw - 24px);
    height:min(900px,100dvh - 44px);
    border-radius:42px;
    box-shadow:0 40px 90px rgba(20,15,10,.45), inset 0 0 0 2px #2a2a2a;
    overflow:hidden;
  }
}

.screen{
  position:relative;width:100%;height:100dvh;
  background:var(--bg);
  display:flex;flex-direction:column;
  transition:background .5s var(--ease),color .5s var(--ease);
  color:var(--text);
}

/* App scroll area */
.app{
  flex:1 1 auto;overflow-y:auto;overflow-x:hidden;
  padding:max(env(safe-area-inset-top),18px) 24px 26px;
  -webkit-overflow-scrolling:touch;
}
.app::-webkit-scrollbar{display:none;}

/* ============ Typografi & gemensamt — STORA storlekar ============ */
h1,h2,h3{margin:0;font-weight:600;letter-spacing:.2px;line-height:1.2;}
.app{font-family:-apple-system,"Segoe UI",system-ui,sans-serif;}
.serif{font-family:"Georgia",serif;}
p{margin:0;line-height:1.6;color:var(--text-2);}

.eyebrow{
  font-size:13px;letter-spacing:3px;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:12px;
}
.title{font-size:32px;color:var(--text);font-family:"Georgia",serif;line-height:1.18;}
.subtitle{font-size:18px;margin-top:12px;}

/* Knappar — stora touch-ytor (minst 60px höga) */
.btn{
  border:none;border-radius:18px;font-size:20px;font-weight:700;cursor:pointer;
  padding:20px 18px;width:100%;font-family:inherit;min-height:62px;
  transition:transform .15s var(--ease),background .25s var(--ease),opacity .2s;
}
.btn:active{transform:scale(.975);}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:active{background:var(--accent-strong);}
.btn-ghost{background:transparent;color:var(--accent);box-shadow:inset 0 0 0 2px var(--line);}
.btn-soft{background:var(--surface-2);color:var(--text);}
.btn-text{background:none;color:var(--text-2);width:auto;padding:12px;font-weight:600;font-size:16px;min-height:0;}
.btn[disabled]{opacity:.45;pointer-events:none;}

.row{display:flex;gap:12px;}
.row .btn{width:auto;flex:1;}

/* Inmatning */
.field{margin-bottom:16px;}
.label{display:block;font-size:16px;color:var(--text-2);margin-bottom:8px;font-weight:600;}
.input{
  width:100%;padding:18px 16px;border-radius:14px;border:2px solid var(--line);
  background:var(--surface);color:var(--text);font-size:18px;font-family:inherit;outline:none;
  transition:border .2s;
}
.input:focus{border-color:var(--accent);}

/* Valkort — stora */
.choice{
  display:flex;align-items:center;gap:16px;
  padding:20px;border-radius:18px;background:var(--surface);
  border:2px solid var(--line);cursor:pointer;margin-bottom:14px;
  transition:border .2s,background .2s,transform .15s var(--ease);
}
.choice:active{transform:scale(.985);}
.choice.sel{border-color:var(--accent);background:var(--highlight);}
.choice .c-ico{
  width:52px;height:52px;border-radius:14px;flex:0 0 auto;
  display:grid;place-items:center;background:var(--surface-2);color:var(--accent);font-size:26px;
}
.choice .c-ico svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.8;}
.choice .c-txt{flex:1;text-align:left;}
.choice .c-txt b{display:block;color:var(--text);font-size:19px;font-weight:700;}
.choice .c-txt span{font-size:15px;color:var(--text-2);}
.choice .c-check{margin-left:auto;width:26px;height:26px;border-radius:50%;border:2.5px solid var(--line);flex:0 0 auto;transition:.2s;}
.choice.sel .c-check{background:var(--accent);border-color:var(--accent);box-shadow:inset 0 0 0 4px var(--surface);}

.chips{display:flex;flex-wrap:wrap;gap:10px;}
.chip{
  padding:13px 18px;border-radius:50px;font-size:16px;font-weight:600;
  background:var(--surface);border:2px solid var(--line);color:var(--text);cursor:pointer;
  transition:.2s;
}
.chip.sel{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ============ Onboarding ============ */
.ob{min-height:100%;display:flex;flex-direction:column;}
.ob-head{padding:14px 0 22px;}
.ob-body{flex:1;}
.ob-foot{padding-top:18px;}
.progress{display:flex;gap:6px;margin-bottom:22px;}
.progress i{height:5px;flex:1;border-radius:3px;background:var(--line);transition:background .3s;}
.progress i.on{background:var(--accent);}
.skip{position:absolute;top:max(env(safe-area-inset-top),22px);right:24px;z-index:5;}

/* Logo */
.logo-wrap{display:flex;flex-direction:column;align-items:center;gap:18px;}
.logo-mark{width:96px;height:96px;}
.logo-word{
  font-family:-apple-system,system-ui,sans-serif;
  letter-spacing:8px;font-weight:700;font-size:24px;color:var(--taupe);
  text-transform:uppercase;
}
.screen[data-theme="dark"] .logo-word{color:var(--moon);}

/* Splash */
.splash{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;text-align:center;padding:30px;}
.splash .tag{color:var(--text-2);font-size:19px;max-width:300px;line-height:1.5;}

/* ============ Generering / laddning ============ */
.gen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:28px;padding:30px;}
.orb{
  width:130px;height:130px;border-radius:50%;position:relative;
  background:radial-gradient(circle at 40% 35%, var(--highlight), var(--surface-2));
  box-shadow:0 0 60px -10px var(--accent);
  animation:breathe 4.5s var(--ease) infinite;
}
.orb::after{
  content:"";position:absolute;inset:14px;border-radius:50%;
  border:2px solid var(--accent);opacity:.35;
  animation:breathe 4.5s var(--ease) infinite reverse;
}
@keyframes breathe{0%,100%{transform:scale(.86);}50%{transform:scale(1.06);}}
.gen .step-txt{font-size:19px;color:var(--text);min-height:26px;font-weight:500;}
.gen .sub{font-size:15px;color:var(--text-2);}

/* ============ Player ============ */
.player{height:100%;display:flex;flex-direction:column;}
.player-top{display:flex;align-items:center;justify-content:space-between;padding:6px 0 16px;}
.player-top .c-btn{background:none;border:none;cursor:pointer;color:var(--text);display:grid;place-items:center;width:48px;height:48px;}
.player-top .c-btn svg{width:28px;height:28px;}
.cover{
  width:100%;aspect-ratio:16/10;border-radius:var(--r-lg);margin-bottom:20px;
  background:linear-gradient(155deg,var(--deep-teal),var(--teal) 55%,#3d7790);
  display:flex;align-items:flex-end;padding:24px;color:#fff;position:relative;overflow:hidden;
}
.cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cover .veil{position:absolute;inset:0;background:linear-gradient(to top, rgba(20,15,10,.55), rgba(20,15,10,0) 60%);}
.cover .wave{position:absolute;inset:0;opacity:.18;}
.cover h2{font-family:"Georgia",serif;font-size:26px;font-weight:700;position:relative;text-shadow:0 1px 8px rgba(0,0,0,.35);}
.player .meta{font-size:15px;color:var(--text-2);margin-bottom:4px;}

.scrub{margin:18px 0 6px;}
.scrub .bar{height:6px;border-radius:3px;background:var(--line);position:relative;overflow:hidden;}
.scrub .bar i{position:absolute;left:0;top:0;height:100%;background:var(--accent);width:0;}
.scrub .times{display:flex;justify-content:space-between;font-size:14px;color:var(--text-2);margin-top:8px;font-variant-numeric:tabular-nums;}

.controls{display:flex;align-items:center;justify-content:center;gap:28px;margin:14px 0 14px;}
.controls .c-btn{background:none;border:none;cursor:pointer;color:var(--text);display:grid;place-items:center;width:56px;height:56px;}
.controls .c-btn svg{width:34px;height:34px;fill:currentColor;}
.controls .play{
  width:84px;height:84px;border-radius:50%;background:var(--accent);color:#fff;
  display:grid;place-items:center;cursor:pointer;border:none;
  box-shadow:0 12px 28px -8px var(--accent);transition:transform .15s var(--ease);
}
.controls .play:active{transform:scale(.94);}
.controls .play svg{width:36px;height:36px;fill:#fff;}

/* Hastighet */
.speed{display:flex;gap:10px;justify-content:center;margin-bottom:14px;}
.speed .chip{font-size:15px;padding:10px 16px;}

.player .actions{display:flex;gap:12px;margin-top:auto;padding-bottom:6px;}
.player .actions .btn{font-size:16px;padding:16px 10px;min-height:0;}

/* Story text reader — STOR text för äldre */
.reader{
  background:var(--surface);border-radius:var(--r);padding:22px;margin-top:6px;
  border:1px solid var(--line);
}
.reader p{font-family:"Georgia",serif;color:var(--text);font-size:20px;line-height:1.75;margin-bottom:16px;transition:background .3s;border-radius:8px;}
.reader p:last-child{margin-bottom:0;}
.reader p.speaking{background:var(--highlight);box-shadow:0 0 0 8px var(--highlight);}

/* ============ Hem / kort ============ */
.greeting{padding:10px 0 18px;}
.greeting .hi{font-size:17px;color:var(--text-2);}
.greeting .big{font-family:"Georgia",serif;font-size:30px;color:var(--text);margin-top:4px;}

.card{
  background:var(--surface);border-radius:var(--r);border:1px solid var(--line);
  padding:20px;margin-bottom:16px;
}
.hero-card{
  background:linear-gradient(160deg,var(--deep-teal),var(--teal));color:#fff;border:none;position:relative;overflow:hidden;
}
.hero-card .wave{position:absolute;right:-20px;bottom:-20px;width:170px;opacity:.16;}
.hero-card .k{font-size:13px;letter-spacing:2px;text-transform:uppercase;opacity:.85;}
.hero-card h3{font-family:"Georgia",serif;font-size:24px;margin:8px 0 6px;font-weight:700;}
.hero-card .hsub{font-size:15px;opacity:.9;margin-bottom:16px;}
.hero-card .btn{background:#fff;color:var(--deep-teal);}

.sec-h{font-size:15px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-2);font-weight:700;margin:24px 0 14px;}

.tile{
  display:flex;gap:16px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);padding:15px;margin-bottom:12px;cursor:pointer;
  transition:transform .15s var(--ease);position:relative;
}
.tile:active{transform:scale(.99);}
.tile .thumb{width:64px;height:64px;border-radius:15px;flex:0 0 auto;background:linear-gradient(150deg,var(--teal),var(--deep-teal));display:grid;place-items:center;color:#fff;font-size:28px;overflow:hidden;position:relative;}
.tile .thumb img{width:100%;height:100%;object-fit:cover;}
.tile .t-txt{flex:1;min-width:0;}
.tile .t-txt b{display:block;color:var(--text);font-size:18px;font-weight:700;}
.tile .t-txt span{font-size:14px;color:var(--text-2);}
.tile .t-lock{margin-left:auto;color:var(--text-2);flex:0 0 auto;}
.tile .t-lock svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.8;}
.tile.locked{opacity:.92;}
.tile .free-badge{position:absolute;top:-8px;left:14px;background:var(--gold);color:#fff;font-size:11px;font-weight:800;letter-spacing:1px;padding:3px 9px;border-radius:20px;text-transform:uppercase;}

/* settings rows */
.set-row{display:flex;align-items:center;justify-content:space-between;padding:18px 4px;border-bottom:1px solid var(--line);}
.set-row:last-child{border-bottom:none;}
.set-row .s-txt b{display:block;color:var(--text);font-size:17px;font-weight:700;}
.set-row .s-txt span{font-size:14px;color:var(--text-2);}
.switch{width:56px;height:32px;border-radius:50px;background:var(--line);position:relative;cursor:pointer;transition:background .25s;flex:0 0 auto;}
.switch.on{background:var(--accent);}
.switch i{position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;background:#fff;transition:left .25s var(--ease);box-shadow:0 1px 3px rgba(0,0,0,.25);}
.switch.on i{left:27px;}

/* Paywall */
.pay-plan{
  border:2px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:14px;cursor:pointer;position:relative;background:var(--surface);
  transition:border .2s,background .2s;
}
.pay-plan.sel{border-color:var(--accent);background:var(--highlight);}
.pay-plan .badge{position:absolute;top:-11px;right:16px;background:var(--gold);color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;padding:5px 12px;border-radius:20px;text-transform:uppercase;}
.pay-plan .pp-top{display:flex;justify-content:space-between;align-items:baseline;}
.pay-plan b{color:var(--text);font-size:18px;}
.pay-plan .price{color:var(--text);font-size:23px;font-weight:700;font-family:"Georgia",serif;}
.pay-plan .price small{font-size:14px;color:var(--text-2);font-weight:400;}
.pay-plan .note{font-size:14px;color:var(--text-2);margin-top:5px;}

.feat{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px;}
.feat svg{width:24px;height:24px;flex:0 0 auto;stroke:var(--accent);fill:none;stroke-width:2.4;margin-top:1px;}
.feat span{font-size:17px;color:var(--text);line-height:1.4;}

/* ============ Tab bar ============ */
.tabbar{
  flex:0 0 auto;display:flex;background:var(--surface);
  border-top:1px solid var(--line);padding:10px 8px max(env(safe-area-inset-bottom),14px);
  font-family:-apple-system,system-ui,sans-serif;
}
.tab{
  flex:1;background:none;border:none;cursor:pointer;color:var(--text-2);
  display:flex;flex-direction:column;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:6px;
}
.tab svg{width:27px;height:27px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.tab.active{color:var(--accent);}

/* Utility */
.hidden{display:none !important;}
.center{text-align:center;}
.mt{margin-top:16px;}
.mt-lg{margin-top:28px;}
.mb{margin-bottom:16px;}
.muted{color:var(--text-2);font-size:16px;}
.fade-in{animation:fade .45s var(--ease);}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

.toast{
  position:fixed;left:50%;bottom:104px;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--moon);padding:14px 22px;border-radius:50px;font-size:15px;font-weight:600;
  font-family:-apple-system,system-ui,sans-serif;opacity:0;pointer-events:none;transition:.35s var(--ease);z-index:40;white-space:nowrap;
}
.screen[data-theme="dark"] .toast{background:var(--moon);color:var(--night);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* Locked overlay */
.lock-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:24px;padding:34px;}
.lock-ico{width:88px;height:88px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;color:var(--accent);}
.lock-ico svg{width:40px;height:40px;fill:none;stroke:currentColor;stroke-width:1.8;}
