/* Grundaren — delad stilmall (index, ansokan, portal) */
:root{
  --bone:#f2ede4; --bone-2:#eae3d6;
  --ink:#15130e; --ink-soft:#56503f; --ink-faint:#8c8472;
  --cream:#f2ede4; --cream-soft:rgba(242,237,228,.62);
  --amber:#cf8a2e; --amber-bright:#e3a53c;
  --line:rgba(21,19,14,.15); --line-soft:rgba(21,19,14,.08); --line-cream:rgba(242,237,228,.16);
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",-apple-system,sans-serif;
  --maxw:1240px; --radius:0 16px 0 16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bone);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
::selection{background:var(--amber);color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 36px}
@media(max-width:600px){.wrap{padding:0 22px}}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.018em}
p{max-width:60ch}
a{color:inherit}
em{font-style:italic}

#curtain{position:fixed;inset:0;background:var(--ink);z-index:10000;transform-origin:top;animation:lift 1.1s cubic-bezier(.76,0,.24,1) .35s forwards}
#curtain span{position:absolute;left:36px;bottom:40px;color:var(--cream);font-family:var(--serif);font-size:1.6rem;letter-spacing:-.02em;opacity:0;animation:fadeWord .5s ease .1s forwards}
#curtain span .d{color:var(--amber)}
@keyframes lift{to{transform:scaleY(0)}}
@keyframes fadeWord{to{opacity:1}}

nav{position:sticky;top:0;z-index:100;background:rgba(242,237,228,.82);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.mark{font-family:var(--serif);font-size:1.4rem;letter-spacing:-.02em;text-decoration:none}
.mark .d{color:var(--amber)}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;text-decoration:none;color:var(--ink-soft);transition:color .25s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{border:1px solid var(--ink);padding:9px 19px;border-radius:var(--radius);transition:all .3s}
.nav-cta:hover{background:var(--ink);color:var(--bone)}
@media(max-width:880px){.nav-links a:not(.nav-cta){display:none}}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

section{position:relative}
.pad{padding:130px 0}
@media(max-width:600px){.pad{padding:84px 0}}
.dark{background:var(--ink);color:var(--cream)}
.dark h1,.dark h2,.dark h3{color:var(--cream)}
.eyebrow{display:flex;align-items:center;gap:16px;font-size:.74rem;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-faint);margin-bottom:40px}
.eyebrow .num{font-family:var(--serif);font-size:1.05rem;color:var(--amber);letter-spacing:0}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--line)}
.dark .eyebrow{color:var(--cream-soft)}.dark .eyebrow::after{background:var(--line-cream)}

.hero{padding-top:clamp(40px,8vh,90px);padding-bottom:90px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(3rem,8vw,6.6rem);font-weight:300;max-width:13ch}
.hero h1 .it{font-style:italic;color:var(--amber)}
.hero .kicker{font-size:.82rem;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-faint);margin-bottom:34px}
.hero-img{border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:0 30px 80px -40px rgba(21,19,14,.5)}
.hero-img img{width:100%;display:block}
.hero-cta{margin-top:44px;display:flex;flex-wrap:wrap;gap:24px 34px;align-items:center}
.hero-note{font-size:.95rem;color:var(--ink-soft);max-width:30ch}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:40px}.hero-img{order:-1;max-width:440px}}

.btn{display:inline-block;background:var(--ink);color:var(--bone);font-size:.92rem;letter-spacing:.03em;text-decoration:none;padding:17px 32px;border-radius:var(--radius);border:1px solid var(--ink);transition:all .3s;cursor:pointer;font-family:var(--sans)}
.btn:hover{background:var(--amber);border-color:var(--amber);color:var(--ink);transform:translateY(-2px)}
.btn-amber{background:var(--amber);border-color:var(--amber);color:var(--ink)}
.btn-amber:hover{background:var(--amber-bright);border-color:var(--amber-bright)}
.dark .btn{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.dark .btn:hover{background:var(--amber);border-color:var(--amber)}
.btn[disabled]{opacity:.5;cursor:default;transform:none}

.statement{font-family:var(--serif);font-weight:300;font-size:clamp(2.1rem,5.4vw,3.7rem);line-height:1.08;letter-spacing:-.02em;max-width:17ch}

.premiss{display:grid;grid-template-columns:1.2fr .8fr;gap:64px;align-items:end;margin-top:46px}
.premiss .txt p{margin-bottom:22px;color:var(--ink-soft)}
.premiss .txt strong{color:var(--ink);font-weight:600}
.premiss .art{border-radius:var(--radius);overflow:hidden;background:#fff}
.premiss .art img{width:100%;display:block}
.premiss .art figcaption{font-size:.78rem;color:var(--ink-faint);padding:12px 4px 0;font-style:italic;font-family:var(--serif)}
@media(max-width:880px){.premiss{grid-template-columns:1fr;gap:36px}}

.mirror{margin-top:50px;border-top:1px solid var(--line-cream)}
.mirror li{list-style:none;display:flex;gap:26px;align-items:baseline;padding:24px 0;border-bottom:1px solid var(--line-cream);font-size:clamp(1.1rem,2.3vw,1.5rem);font-family:var(--serif);font-weight:300;color:var(--cream);transition:padding-left .35s,color .35s}
.mirror li:hover{padding-left:16px;color:var(--amber-bright)}
.mirror li .i{font-family:var(--sans);font-size:.7rem;color:var(--amber);letter-spacing:.1em;flex:0 0 26px;transform:translateY(-3px)}
.punch{font-family:var(--serif);font-style:italic;font-size:clamp(1.9rem,5.5vw,3.4rem);margin-top:60px;color:var(--amber-bright);line-height:1.05}
.qualifier{margin-top:28px;color:var(--cream-soft);max-width:50ch}

.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split .art{border-radius:var(--radius);overflow:hidden;background:#fff}
.split .art img{width:100%;display:block}
.split .lede{font-size:clamp(1.15rem,2vw,1.4rem);font-family:var(--serif);font-weight:300;color:var(--ink-soft);line-height:1.45}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:34px}}

.etable{width:100%;border-collapse:collapse;margin-top:46px;font-size:1rem}
.etable th,.etable td{text-align:left;padding:20px 16px;border-bottom:1px solid var(--line)}
.etable thead th{font-family:var(--sans);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--ink-faint)}
.etable tbody th{font-family:var(--serif);font-weight:400;font-size:1.05rem}
.etable td{font-variant-numeric:tabular-nums;color:var(--ink-soft)}
.etable tbody tr:hover{background:rgba(207,138,46,.06)}
@media(max-width:680px){.etable{font-size:.88rem}.etable th,.etable td{padding:13px 9px}}

.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:48px;border:1px solid var(--line)}
.pillar{background:var(--bone-2);padding:36px 30px}
.pillar .pnum{font-family:var(--serif);color:var(--amber);font-size:1.5rem}
.pillar h3{font-size:1.45rem;margin:12px 0 12px}
.pillar p{font-size:.96rem;color:var(--ink-soft)}
@media(max-width:820px){.pillars{grid-template-columns:1fr}}

.module{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center;padding:72px 0;border-top:1px solid var(--line)}
.module.flip .m-art{order:2}
.m-art{border-radius:var(--radius);overflow:hidden;background:#fff}
.m-art img{width:100%;display:block}
.module .mnum{font-family:var(--serif);font-size:1rem;color:var(--amber);letter-spacing:.05em;margin-bottom:14px}
.module h3{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:14px}
.module p{color:var(--ink-soft);font-size:1.05rem}
@media(max-width:880px){.module{grid-template-columns:1fr;gap:28px;padding:48px 0}.module.flip .m-art{order:0}}
.loop{margin-top:44px;font-size:.92rem;color:var(--ink-faint);letter-spacing:.03em;max-width:70ch}
.loop b{color:var(--ink-soft);font-weight:500}

.kit{text-align:center}
.kit .big{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(2rem,6vw,4rem);line-height:1.1;color:var(--cream);max-width:18ch;margin:0 auto}
.kit .big .a{color:var(--amber-bright)}
.kit .sub{margin:40px auto 0;max-width:56ch;color:var(--cream-soft)}
.kit .six{margin-top:40px;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 10px}
.kit .six span{border:1px solid var(--line-cream);border-radius:var(--radius);padding:8px 18px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cream-soft)}

.pay-quote{font-family:var(--serif);font-weight:300;font-size:clamp(1.9rem,5.4vw,3.4rem);line-height:1.08;max-width:15ch}
.pay-quote em{color:var(--amber)}
.pay-note{margin-top:46px;display:grid;grid-template-columns:1fr 1fr;gap:48px}
.pay-note .box{border-left:2px solid var(--amber);padding-left:24px}
.pay-note h4{font-family:var(--serif);font-weight:400;font-size:1.2rem;margin-bottom:10px}
.pay-note p{font-size:.97rem;color:var(--ink-soft)}
@media(max-width:820px){.pay-note{grid-template-columns:1fr;gap:28px}}

.nivå{display:grid;grid-template-columns:repeat(3,1fr);gap:46px;margin-top:48px}
.nivå h3{font-size:1.35rem;margin-bottom:12px;color:var(--cream)}
.nivå p{font-size:.96rem;color:var(--cream-soft)}
@media(max-width:820px){.nivå{grid-template-columns:1fr;gap:34px}}

.forwhom{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:48px}
.forwhom h3{font-size:1.4rem;margin-bottom:22px}
.forwhom ul{list-style:none}
.forwhom li{padding:14px 0 14px 30px;position:relative;border-bottom:1px solid var(--line-soft);color:var(--ink-soft)}
.forwhom li::before{position:absolute;left:0;top:13px;font-family:var(--serif)}
.forwhom .yes li::before{content:"—";color:var(--amber)}
.forwhom .no li::before{content:"×";color:var(--ink-faint)}
@media(max-width:760px){.forwhom{grid-template-columns:1fr;gap:34px}}

.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:42px;margin-top:48px}
.voice blockquote{font-family:var(--serif);font-weight:300;font-style:italic;font-size:1.22rem;line-height:1.35}
.voice cite{display:block;margin-top:18px;font-style:normal;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint)}
@media(max-width:820px){.voices{grid-template-columns:1fr;gap:32px}}

.author{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:center;margin-top:36px}
.author .ph{border-radius:var(--radius);overflow:hidden}
.author .ph img{width:100%;display:block}
.author .ph figcaption{font-size:.74rem;color:var(--ink-faint);margin-top:10px;font-style:italic;font-family:var(--serif)}
.author h2{margin-bottom:22px}
.author p{margin-bottom:18px;color:var(--ink-soft)}
.author .last{font-family:var(--serif);font-style:italic;color:var(--ink);font-size:1.18rem}
@media(max-width:820px){.author{grid-template-columns:1fr;gap:28px}.author .ph{max-width:380px}}

.apply{text-align:center}
.apply h2{font-size:clamp(2.6rem,8vw,5rem);max-width:13ch;margin:0 auto 26px;font-weight:300}
.apply h2 em{color:var(--amber-bright)}
.apply p{max-width:46ch;margin:0 auto 42px;color:var(--cream-soft)}

footer{background:#0d0c09;color:var(--cream);padding:74px 0 58px}
.foot-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;align-items:flex-start}
footer .tag{color:var(--cream-soft);max-width:34ch;margin-top:14px;font-size:.95rem}
.foot-links{display:flex;gap:30px;flex-wrap:wrap}
.foot-links a{color:var(--cream-soft);text-decoration:none;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;transition:color .25s}
.foot-links a:hover{color:var(--amber-bright)}

/* ---------- FORMULÄR (ansökan) ---------- */
.form{max-width:680px;margin-top:10px}
.q{padding:38px 0;border-top:1px solid var(--line-cream)}
.q:first-child{border-top:none}
.q .qn{font-family:var(--serif);color:var(--amber);font-size:.95rem;letter-spacing:.04em;margin-bottom:10px}
.q label{display:block;font-family:var(--serif);font-weight:300;font-size:clamp(1.3rem,3vw,1.8rem);line-height:1.2;color:var(--cream);margin-bottom:8px}
.q .hint{color:var(--cream-soft);font-size:.92rem;margin-bottom:18px;max-width:54ch}
.field{display:flex;flex-direction:column;gap:8px}
textarea,input[type=text],input[type=email],input[type=url]{
  width:100%;background:rgba(242,237,228,.04);border:1px solid var(--line-cream);border-radius:var(--radius);
  color:var(--cream);font-family:var(--sans);font-size:1.02rem;line-height:1.55;padding:16px 18px;transition:border-color .25s,background .25s;resize:vertical}
textarea{min-height:130px}
textarea:focus,input:focus{outline:none;border-color:var(--amber);background:rgba(242,237,228,.07)}
textarea::placeholder,input::placeholder{color:rgba(242,237,228,.35)}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.meta-grid .full{grid-column:1/-1}
.field .lab{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--cream-soft)}
@media(max-width:600px){.meta-grid{grid-template-columns:1fr}}
.form-status{margin-top:20px;font-size:.95rem;color:var(--amber-bright);min-height:1.2em}
.thanks{text-align:center;max-width:48ch;margin:0 auto}
.thanks h2{font-weight:300;font-style:italic;color:var(--cream);margin-bottom:18px}
.thanks p{color:var(--cream-soft);margin:0 auto}

/* ---------- PORTAL ---------- */
.login{max-width:440px;margin:0 auto;text-align:center}
.login .card{border:1px solid var(--line-cream);border-radius:var(--radius);padding:44px 38px;margin-top:34px;text-align:left}
.login .card .lab{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--cream-soft);display:block;margin-bottom:8px}
.login .card .btn{width:100%;text-align:center;margin-top:18px}
.login .small{margin:22px auto 0;font-size:.86rem;color:var(--cream-soft)}
.login .small a{color:var(--amber-bright);text-decoration:none}
.demo-link{display:inline-block;margin-top:26px;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--cream-soft);border-bottom:1px solid var(--line-cream);text-decoration:none;cursor:pointer}
.demo-link:hover{color:var(--amber-bright)}

.dash{display:none}
.dash.show{display:block}
.dash-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:12px;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:40px}
.dash-head h2{font-weight:300}
.dash-head .badge{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--amber);border:1px solid var(--amber);border-radius:var(--radius);padding:5px 12px}
.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:30px}
@media(max-width:880px){.dash-grid{grid-template-columns:1fr}}
.panel{border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;background:var(--bone-2)}
.panel h3{font-size:1.3rem;margin-bottom:18px}
.wb-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.wb-row:last-child{border-bottom:none}
.wb-row .n{font-family:var(--serif);color:var(--amber);width:26px}
.wb-row .t{flex:1}
.wb-row .t .nm{font-family:var(--serif);font-size:1.1rem}
.bar{height:6px;background:rgba(21,19,14,.1);border-radius:6px;overflow:hidden;margin-top:6px}
.bar i{display:block;height:100%;background:var(--amber)}
.next .when{font-family:var(--serif);font-size:1.6rem;color:var(--ink)}
.next .what{color:var(--ink-soft);font-size:.95rem;margin-top:4px}
.msg{padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:.95rem;color:var(--ink-soft)}
.msg:last-child{border-bottom:none}
.msg b{color:var(--ink);font-weight:600;font-family:var(--serif)}
