/* ═══════════════════════════════════════════════════
   DLS SALONJA — styles.css v3 (Royal Navy · Chrome)
═══════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  /* 2026 — Royal Navy + Chrome */
  --chrome:#b8cce0;
  --chrome2:#d4e6f8;
  --chrome3:#6a8aaa;
  --champ:#c8daf0;
  --bone:#dcedf8;
  --bg:#010912;
  --bg2:#020d1e;
  --bg3:#030f28;
  --text:#d8eaf8;
  --dim:#5a7898;
  --dim2:#344e68;
  --accent:#a8c4dc;
  --shadow:0 24px 80px rgba(0,4,20,.9);
}

html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Josefin Sans',sans-serif;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ═══ LOADING ═══ */
@keyframes barIn{from{width:0}to{width:100%}}
@keyframes pulse{0%,100%{opacity:.4;transform:scaleY(1);}50%{opacity:1;transform:scaleY(1.4);}}
@keyframes fu{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes chromePulse{0%,100%{filter:drop-shadow(0 2px 18px rgba(160,210,255,.45));}50%{filter:drop-shadow(0 2px 36px rgba(160,210,255,.85));}}

#LS{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(ellipse at center,#020f2a 0%,#010912 65%,#000508 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s ease;
}
#LS.hide{opacity:0;visibility:hidden;pointer-events:none;}
.ll{
  font-family:'Cinzel',serif;
  font-size:2.4rem;font-weight:400;letter-spacing:.22em;
  background:linear-gradient(180deg,#dcedf8 0%,#a8c8e8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.8rem;
  animation:chromePulse 2.8s ease infinite;
}
.ls{font-size:.58rem;letter-spacing:.52em;text-transform:uppercase;color:var(--dim);margin-bottom:2.8rem;}
.lb{width:220px;height:1px;background:rgba(160,210,255,.1);overflow:hidden;}
.lf{height:100%;background:linear-gradient(to right,var(--chrome),var(--chrome2));animation:barIn 3s ease forwards;box-shadow:0 0 12px rgba(160,210,255,.55);}

/* ═══ NAV ═══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:1.4rem 5vw;
  display:flex;justify-content:space-between;align-items:center;gap:2rem;
  background:linear-gradient(to bottom,rgba(1,9,18,.93),rgba(1,9,18,.6) 60%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:all .4s ease;
}
nav.scrolled{padding:.9rem 5vw;background:rgba(1,9,18,.97);border-bottom:1px solid rgba(160,210,255,.07);}
.nlogo{font-family:'Cinzel',serif;font-size:1.15rem;font-weight:700;color:var(--chrome);text-decoration:none;letter-spacing:.08em;line-height:1;}
.nlogo span{display:block;font-size:.55rem;font-family:'Josefin Sans',sans-serif;font-weight:300;color:var(--text);letter-spacing:.4em;text-transform:uppercase;opacity:.45;margin-top:3px;}
.nl{display:flex;gap:2.6rem;list-style:none;}
.nl a{color:var(--dim);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;text-decoration:none;transition:color .3s,text-shadow .3s;}
.nl a:hover{color:var(--chrome2);text-shadow:0 0 14px rgba(160,210,255,.55);}

.lang-toggle{display:flex;align-items:center;gap:.4rem;}
.lb-btn{background:none;border:none;cursor:pointer;color:var(--dim);font-size:.62rem;font-weight:600;letter-spacing:.2em;padding:.3rem .5rem;font-family:inherit;transition:color .25s;}
.lb-btn.active{color:var(--chrome2);text-shadow:0 0 8px rgba(160,210,255,.5);}
.lb-btn:hover{color:var(--chrome2);}
.lb-sep{color:rgba(160,210,255,.25);font-size:.6rem;}

.nav-mobile{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;}
.nav-mobile span{display:block;width:24px;height:1px;background:var(--chrome);transition:all .3s;}

/* ═══ HERO ═══ */
#hero{height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
#hc{position:absolute;inset:0;width:100%;height:100%;display:block;}
.hi{position:relative;z-index:5;text-align:center;padding:0 4vw;}
.he{font-family:'Cormorant Garamond',serif;font-size:clamp(.62rem,1.1vw,.78rem);letter-spacing:.56em;text-transform:uppercase;color:var(--chrome);margin-bottom:1.8rem;opacity:0;animation:fu .9s .4s ease forwards;}
.hh{
  font-family:'Cinzel',serif;
  font-size:clamp(2.8rem,7.8vw,7.5rem);font-weight:400;line-height:.92;letter-spacing:-.01em;
  opacity:0;animation:fu 1.1s .55s ease forwards;
}
.hh span{
  display:block;font-weight:300;
  background:linear-gradient(180deg,#dcedf8 0%,#a8c8e8 55%,#5888b8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 2px 20px rgba(140,190,240,.2));
}
.hh em{
  font-style:italic;display:block;
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:.72em;line-height:1;margin-top:.18em;
  color:rgba(200,230,255,.76);
  letter-spacing:.005em;
}
.hs{font-family:'Cormorant Garamond',serif;font-size:clamp(.9rem,1.6vw,1.2rem);letter-spacing:.18em;color:rgba(180,215,250,.5);margin-top:2rem;opacity:0;animation:fu .9s .7s ease forwards;}
.hb{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1.6rem;opacity:0;animation:fu .9s .82s ease forwards;}
.badge{font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;padding:.42rem 1rem;border:1px solid rgba(160,210,255,.18);color:var(--dim);transition:all .3s;}
.badge:hover{border-color:var(--chrome);color:var(--chrome);}
.hcta{margin-top:2.4rem;opacity:0;animation:fu .9s .94s ease forwards;}

.btn{
  display:inline-block;padding:1rem 3.2rem;
  font-size:.68rem;letter-spacing:.38em;text-transform:uppercase;font-weight:400;
  text-decoration:none;color:var(--bone);
  background:transparent;border:1px solid rgba(160,210,255,.4);
  transition:all .45s cubic-bezier(.2,.8,.2,1);
  cursor:pointer;font-family:'Josefin Sans',sans-serif;
  position:relative;overflow:hidden;
}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(160,210,255,.1),rgba(160,210,255,0));opacity:0;transition:opacity .5s;}
.btn:hover{border-color:var(--chrome2);color:var(--bone);box-shadow:0 12px 48px rgba(140,190,240,.2),inset 0 0 60px rgba(140,190,240,.04);transform:translateY(-2px);}
.btn:hover::before{opacity:1;}

.sh{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fu .9s 1.2s ease forwards;}
.sh span{font-size:.52rem;letter-spacing:.46em;text-transform:uppercase;color:var(--dim);}
.sb{width:1px;height:48px;background:linear-gradient(to bottom,rgba(160,210,255,.75),transparent);transform-origin:top;animation:pulse 2.2s 1.5s infinite;}

/* ═══ SCROLL SECTIONS ═══ */
.sect{height:500vh;position:relative;}
.stick{position:sticky;top:0;height:100vh;overflow:hidden;background:var(--bg);}
.tc{position:absolute;inset:0;width:100%!important;height:100%!important;display:block;}
.ov{position:absolute;z-index:10;inset:0;display:flex;align-items:center;pointer-events:none;}
.ov.r{justify-content:flex-end;align-items:flex-start;padding-top:9vh;}

.pn{
  max-width:460px;width:100%;margin:0 4vw;
  padding:2.4rem 2.4rem 2.6rem;pointer-events:all;
  background:linear-gradient(135deg,rgba(1,9,18,.84),rgba(2,13,30,.66));
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(160,210,255,.09);
  border-left:2px solid rgba(160,210,255,.35);
  box-shadow:var(--shadow),inset 0 0 40px rgba(0,10,30,.3);
}
.pn.r{text-align:right;border-left:1px solid rgba(160,210,255,.09);border-right:2px solid rgba(160,210,255,.35);}
.stag{font-size:.55rem;letter-spacing:.46em;text-transform:uppercase;color:var(--chrome);text-shadow:0 0 14px rgba(160,210,255,.45);}
.sd{width:50px;height:1px;background:linear-gradient(to right,var(--chrome),transparent);margin:1.2rem 0;}
.sd.r{margin-left:auto;background:linear-gradient(to left,var(--chrome),transparent);}
.sth{font-family:'Cinzel',serif;font-size:clamp(1.7rem,3vw,2.8rem);font-weight:400;line-height:1.1;letter-spacing:-.01em;margin-bottom:1.4rem;text-shadow:0 2px 24px rgba(0,0,0,.95);color:var(--bone);}
.sth em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--champ);opacity:.9;}
.stp{font-family:'Cormorant Garamond',serif;font-size:clamp(.92rem,1.3vw,1.04rem);line-height:1.85;color:rgba(190,220,248,.88);margin-bottom:.8rem;}

.pt{width:100%;height:1px;background:rgba(160,210,255,.08);margin-top:1.8rem;overflow:hidden;}
.pf{height:100%;background:linear-gradient(to right,var(--chrome),var(--chrome2));width:0%;box-shadow:0 0 10px rgba(160,210,255,.55);transition:width .15s linear;}

.step-list{margin-top:1.4rem;display:flex;flex-direction:column;gap:.6rem;}
.step{display:flex;align-items:center;gap:.85rem;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dim2);transition:color .35s;}
.pn.r .step{justify-content:flex-end;}
.step span{color:var(--chrome);font-weight:600;font-family:'Cinzel',serif;font-size:.68rem;opacity:.4;transition:opacity .35s;}
.step em{font-style:normal;font-weight:400;}
.step.active{color:var(--text);}
.step.active span{opacity:1;text-shadow:0 0 10px rgba(160,210,255,.6);}

.sn{position:absolute;bottom:2.4rem;right:5vw;font-family:'Cinzel',serif;font-size:9rem;font-weight:900;color:rgba(160,210,255,.018);line-height:1;pointer-events:none;}
.sl{position:absolute;bottom:1.8rem;left:5vw;font-size:.52rem;letter-spacing:.46em;text-transform:uppercase;color:rgba(160,210,255,.12);}

/* ═══ PRICE LABELS ═══ */
.labels{position:absolute;inset:0;pointer-events:none;z-index:8;}
.label{position:absolute;transform:translate(-50%,-50%);pointer-events:none;opacity:0;transition:opacity .5s ease;}
.label.show{opacity:1;}
.label-card{
  background:rgba(1,6,18,.9);
  border:1px solid rgba(160,210,255,.25);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:.6rem 1rem;white-space:nowrap;
  box-shadow:0 8px 32px rgba(0,0,0,.7),0 0 20px rgba(140,190,240,.06);
  position:relative;
}
.label-card::before{content:'';position:absolute;top:-1px;left:-1px;width:12px;height:1px;background:var(--chrome);}
.label-card::after{content:'';position:absolute;bottom:-1px;right:-1px;width:12px;height:1px;background:var(--chrome);}
.label-name{font-size:.5rem;letter-spacing:.36em;text-transform:uppercase;color:var(--dim);margin-bottom:.25rem;font-weight:400;}
.label-val{font-family:'Cinzel',serif;font-size:.92rem;font-weight:400;color:var(--chrome2);letter-spacing:.02em;}

/* ═══ ABOUT ═══ */
#about{padding:9rem 10vw;background:linear-gradient(180deg,var(--bg),var(--bg2));position:relative;}
#about::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(160,210,255,.2),transparent);}
.ag{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1100px;margin:0 auto;}
.al{font-size:.55rem;letter-spacing:.46em;text-transform:uppercase;color:var(--chrome);margin-bottom:1.4rem;}
.ah{font-family:'Cinzel',serif;font-size:clamp(1.9rem,3.2vw,2.9rem);font-weight:400;line-height:1.1;letter-spacing:-.01em;margin-bottom:1.8rem;color:var(--bone);}
.ah em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--champ);}
.ap{font-family:'Cormorant Garamond',serif;font-size:1.06rem;line-height:1.92;color:rgba(190,220,248,.83);margin-bottom:1rem;}
.ce{list-style:none;margin-top:2rem;}
.ce li{display:flex;align-items:center;gap:.95rem;padding:.85rem 0;border-bottom:1px solid rgba(160,210,255,.06);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(190,220,248,.7);}
.ce li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--chrome);flex-shrink:0;box-shadow:0 0 10px rgba(160,210,255,.65);}
.pb{
  background:linear-gradient(135deg,rgba(140,190,240,.05),rgba(200,230,255,.012));
  border:1px solid rgba(160,210,255,.1);
  aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.pb::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 35% 25%,rgba(140,190,240,.12),transparent 60%);}
.pi{
  font-family:'Cinzel',serif;font-size:5.2rem;font-weight:300;letter-spacing:.08em;
  background:linear-gradient(180deg,#dcedf8 0%,#a8c8e8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  text-align:center;position:relative;z-index:2;
}
.pn2{font-family:'Cormorant Garamond',serif;font-size:1rem;letter-spacing:.24em;color:var(--dim);margin-top:1rem;text-align:center;text-transform:uppercase;}

/* ═══ CONTACT ═══ */
#kontakt{padding:7rem 10vw;background:var(--bg2);position:relative;}
#kontakt::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(160,210,255,.2),transparent);}
.cg{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1180px;margin:0 auto;}
.clb{font-size:.55rem;letter-spacing:.46em;text-transform:uppercase;color:var(--chrome);margin-bottom:1.4rem;}
.ch{font-family:'Cinzel',serif;font-size:clamp(1.8rem,3vw,2.7rem);font-weight:400;line-height:1.12;letter-spacing:-.01em;margin-bottom:2rem;color:var(--bone);}
.ch em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--champ);}
.cd{display:flex;align-items:flex-start;gap:1.2rem;padding:1rem 0;border-bottom:1px solid rgba(160,210,255,.06);}
.ci{width:38px;height:38px;border:1px solid rgba(160,210,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(160,210,255,.03);}
.ci svg{width:14px;height:14px;stroke:var(--chrome);fill:none;stroke-width:1.5;}
.cx{font-family:'Cormorant Garamond',serif;font-size:.98rem;line-height:1.65;color:var(--dim);}
.cx strong{display:block;font-family:'Josefin Sans',sans-serif;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--text);margin-bottom:.25rem;}

.cf{display:flex;flex-direction:column;gap:1.2rem;position:relative;}
.hp-field{position:absolute;left:-9999px;}
.fi{position:relative;}
.fi input,.fi textarea,.fi select{
  width:100%;background:rgba(160,210,255,.02);border:1px solid rgba(160,210,255,.1);
  color:var(--text);padding:1rem 1.1rem;
  font-family:'Josefin Sans',sans-serif;font-size:.78rem;letter-spacing:.1em;
  outline:none;transition:all .3s;resize:none;-webkit-appearance:none;appearance:none;border-radius:0;
}
.fi select{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b8cce0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;
}
.fi select option{background:var(--bg);color:var(--text);}
.fi input:focus,.fi textarea:focus,.fi select:focus{border-color:var(--chrome);background:rgba(160,210,255,.04);box-shadow:0 0 0 1px var(--chrome);}
.fi label{position:absolute;left:1.1rem;top:1rem;font-size:.78rem;letter-spacing:.1em;color:var(--dim2);pointer-events:none;transition:all .25s ease;background:var(--bg2);padding:0 .4rem;}
.fi input:focus+label,.fi input:not(:placeholder-shown)+label,.fi textarea:focus+label,.fi textarea:not(:placeholder-shown)+label{top:-.5rem;font-size:.55rem;color:var(--chrome);letter-spacing:.22em;}

.consent{display:flex;align-items:flex-start;gap:.7rem;font-size:.72rem;color:var(--dim);line-height:1.5;cursor:pointer;}
.consent input{margin-top:.2rem;accent-color:var(--chrome);width:14px;height:14px;}
.consent a{color:var(--chrome);text-decoration:underline;text-underline-offset:2px;}
.form-btn{margin-top:.4rem;}
.form-success{display:none;text-align:center;padding:2rem 1rem;border:1px solid rgba(160,210,255,.28);background:rgba(160,210,255,.04);color:var(--chrome);}
.form-success.show{display:block;animation:fu .6s ease forwards;}
.form-success p{margin-top:.6rem;font-size:.85rem;letter-spacing:.1em;color:var(--text);}

/* ═══ FOOTER ═══ */
footer{background:#01060f;padding:3rem 5vw 2rem;border-top:1px solid rgba(160,210,255,.07);}
.foot{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;}
.flogo{font-family:'Cinzel',serif;font-size:1.05rem;font-weight:700;color:var(--chrome);letter-spacing:.08em;}
.flogo span{font-size:.5rem;font-family:'Josefin Sans',sans-serif;font-weight:300;color:var(--text);letter-spacing:.4em;opacity:.45;}
.fsub{font-size:.55rem;letter-spacing:.36em;text-transform:uppercase;color:var(--dim2);margin-top:.3rem;}
.flinks{display:flex;gap:1.8rem;}
.flinks a{color:var(--dim);font-size:.65rem;letter-spacing:.24em;text-transform:uppercase;text-decoration:none;transition:color .25s;}
.flinks a:hover{color:var(--chrome);}
.fcopy{font-size:.6rem;letter-spacing:.18em;color:var(--dim2);text-transform:uppercase;}

/* ═══ TABLET ≤ 880px ═══ */
@media(max-width:880px){
  /* Nav */
  .nl{display:none;}
  .nav-mobile{display:flex;}
  nav{padding:1rem 5vw;}
  nav.mobile-open .nl{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(1,9,18,.99);
    padding:1.8rem 5vw 1.4rem;gap:1.4rem;
    border-top:1px solid rgba(160,210,255,.09);
    border-bottom:1px solid rgba(160,210,255,.06);
  }

  /* Grids → single column */
  .ag,.cg{grid-template-columns:1fr;gap:2.5rem;}
  /* On tablet: show portrait ABOVE the text */
  .pb{aspect-ratio:16/9;order:-1;}
  #about{padding:5rem 6vw;}
  #kontakt{padding:4rem 6vw;}

  /* Scroll sections */
  .sect{height:320vh;}
  .stick{height:100svh;}

  /* Text panels — full-width, bottom-aligned */
  .ov{align-items:flex-end;padding-bottom:env(safe-area-inset-bottom,0px);}
  .ov.r{justify-content:flex-start;align-items:flex-end;padding-top:0;}
  .pn,.pn.r{
    width:calc(100% - 2.4rem);max-width:none;
    margin:0 1.2rem 2.4rem;padding:1.6rem 1.4rem 1.8rem;
    text-align:left;
    border-left:2px solid rgba(160,210,255,.35);
    border-right:none;border-top:none;border-bottom:none;
    background:linear-gradient(135deg,rgba(1,9,18,.93),rgba(2,13,30,.82));
  }
  .pn.r .step,.pn .step{justify-content:flex-start;}
  .pn.r .sd,.pn .sd{margin-left:0;background:linear-gradient(to right,var(--chrome),transparent);}
  .sth{font-size:clamp(1.5rem,5vw,2.2rem);}
  .stp{font-size:clamp(.9rem,3vw,1rem);}
  .step-list{display:none;}

  /* Decoration */
  .sn{font-size:5rem;}
  .label-card{padding:.4rem .7rem;}
  .label-name{font-size:.46rem;}
  .label-val{font-size:.78rem;}

  /* Footer */
  .foot{flex-direction:column;text-align:center;gap:1rem;}
  .flinks{justify-content:center;}
}

/* ═══ PHABLET ≤ 640px ═══ */
@media(max-width:640px){
  /* Hero */
  .he{margin-bottom:1.2rem;}
  .hh{font-size:clamp(2.4rem,9vw,3.6rem);}
  .hs{font-size:clamp(.82rem,3.2vw,.94rem);letter-spacing:.12em;margin-top:1.4rem;}
  .hb{gap:.4rem;margin-top:1.2rem;}
  .hcta{margin-top:1.8rem;}
  .sh{bottom:1.8rem;}

  /* About & Contact */
  #about,#kontakt{padding:4rem 5vw;}
  .ah{font-size:clamp(1.6rem,6vw,2.2rem);}
  .ch{font-size:clamp(1.5rem,5.5vw,2rem);}
  .ap{font-size:.98rem;line-height:1.82;}
  .ce li{font-size:.65rem;}

  /* Contact form */
  .fi input,.fi textarea,.fi select{padding:.9rem 1rem;font-size:.76rem;}
  .fi label{left:1rem;top:.9rem;font-size:.76rem;}
  .consent{font-size:.68rem;}

  /* Scroll panels */
  .pn,.pn.r{margin:0 .8rem 1.6rem;padding:1.3rem 1.1rem 1.5rem;}
  .sth{font-size:clamp(1.3rem,5.5vw,1.9rem);}
  .stp{font-size:.92rem;line-height:1.72;}
  .stag{font-size:.5rem;letter-spacing:.4em;}
}

/* ═══ SMALL PHONES ≤ 480px ═══ */
@media(max-width:480px){
  /* Loading */
  .ll{font-size:1.6rem;}
  .ls{font-size:.5rem;letter-spacing:.4em;}

  /* Nav */
  nav{padding:.85rem 5vw;}
  .nlogo{font-size:1rem;}

  /* Hero */
  .hh{font-size:clamp(2rem,10vw,3rem);}
  .hs{font-size:.8rem;letter-spacing:.08em;}
  .hb{gap:.35rem;}
  .badge{font-size:.46rem;padding:.28rem .6rem;}
  .btn{padding:.8rem 2rem;font-size:.6rem;letter-spacing:.26em;}
  .sh{display:none;} /* hide scroll indicator — saves space */

  /* Scroll sections */
  .sect{height:280vh;}
  .pn,.pn.r{margin:0 .6rem 1rem;padding:1.1rem 1rem 1.3rem;}
  .sth{font-size:clamp(1.2rem,7vw,1.7rem);}
  .stp{font-size:.88rem;line-height:1.7;}

  /* About & Contact */
  #about,#kontakt{padding:3.5rem 5vw;}
  .pb{aspect-ratio:4/3;}
  .pi{font-size:3.8rem;}
  .pn2{font-size:.85rem;}

  /* Contact details */
  .cx{font-size:.9rem;}
  .ci{width:32px;height:32px;}
  .ci svg{width:12px;height:12px;}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}
}