/* ============================================================
   Chantima Moen Kosmetisk Klinikk — felles stilark
   Brukes av alle sider (forside + undersider)
   ============================================================ */
:root{
  --cream: #F1E7D2;
  --cream-warm: #EBDDC2;
  --cream-soft: #F7EFDF;
  --cream-card: #EFE3CA;
  --cream-card-2: #E9DAB9;
  --white: #FFFFFF;

  --teal: #1F4845;
  --teal-hover: #173734;
  --teal-deep: #15302E;
  --teal-darker: #0E2422;

  --gold: #C6A876;
  --gold-line: #D6BA88;

  --ink: #2A2A2A;
  --ink-2: #3D3D3D;
  --muted: #6E6A60;
  --muted-2: #8A8578;
  --hair: #D6C9AC;
  --hair-soft: #E4D8BD;

  --maxw: 1180px;
}

*{box-sizing:border-box}
*{min-width:0}
html,body{margin:0;padding:0;overflow-x:clip}
html{scroll-behavior:smooth}
img,iframe,video{max-width:100%}
h1,h2,h3,h4,h5,p,a,span,li{overflow-wrap:break-word}
body{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

.serif{font-family:'Cormorant Garamond','Times New Roman',serif;font-weight:500;letter-spacing:-0.005em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 26px;border-radius:4px;
  font-size:12px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;
  transition:background .15s ease,color .15s ease,transform .1s ease;cursor:pointer;
}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-hover)}
.btn-primary:active{transform:translateY(1px)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-outline:hover{background:rgba(0,0,0,0.04)}
.btn-gold{background:transparent;color:var(--teal);border:1px solid var(--gold)}
.btn-gold:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

/* ---------- HEADER ---------- */
header.site{background:var(--cream-soft);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--hair-soft)}
.nav{display:flex;align-items:center;gap:28px;height:88px;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.logo{display:flex;align-items:center;gap:12px;padding-right:22px}
.logo .mark{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--teal)}
.logo .mark svg{width:36px;height:36px}
.logo .wordmark{line-height:1.05}
.logo .wordmark .a{font-family:'Inter',sans-serif;font-weight:500;letter-spacing:0.18em;font-size:15px;color:var(--ink)}
.logo .wordmark .b{font-family:'Inter',sans-serif;font-weight:400;letter-spacing:0.32em;font-size:9px;color:var(--muted);margin-top:3px}

nav.primary{display:flex;align-items:center;gap:36px;margin-left:24px}
nav.primary > a,
nav.primary .has-drop > a{
  font-size:13px;font-weight:500;letter-spacing:0.14em;color:var(--ink-2);
  text-transform:uppercase;display:inline-flex;align-items:center;gap:4px;transition:color .15s ease;
}
nav.primary > a,.has-drop{position:relative}
nav.primary a:hover{color:var(--teal)}
nav.primary a.active{color:var(--teal)}
nav.primary a.active::after{
  content:'';display:block;position:absolute;bottom:-6px;left:0;right:0;height:2px;background:var(--gold);
}
nav.primary .caret{width:10px;height:10px;display:inline-block;opacity:.7;transition:transform .2s ease}

/* Dropdown (BEHANDLINGER) */
.has-drop{position:relative;display:inline-flex;align-items:center}
.has-drop > a{position:relative;padding:10px 0}
.dropdown{
  position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--cream-soft);border:1px solid var(--hair-soft);border-top:2px solid var(--gold);
  border-radius:4px;box-shadow:0 14px 34px rgba(20,48,46,.12);
  min-width:230px;padding:8px 0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:120;
}
/* usynlig bro som dekker gapet, slik at hover ikke mistes på vei ned */
.dropdown::before{content:'';position:absolute;left:-12px;right:-12px;top:-16px;height:16px}
.has-drop:hover .dropdown,.has-drop:focus-within .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.has-drop:hover .caret{transform:rotate(180deg)}
.dropdown a{
  display:block;padding:11px 22px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;border-bottom:1px solid rgba(0,0,0,.04);transition:background .12s ease,color .12s ease;
}
.dropdown a:last-child{border-bottom:0}
.dropdown a:hover{background:var(--cream-card);color:var(--teal)}

.nav-cta{margin-left:auto}

/* Hamburger */
.hamburger{display:none;width:40px;height:40px;flex-direction:column;justify-content:center;align-items:center;gap:5px;margin-left:auto;background:transparent;border-radius:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .2s ease,opacity .2s ease}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
nav.primary a.nav-cta-mobile{display:none}

/* ---------- PAGE HERO (undersider) ---------- */
.page-hero{background:var(--cream-warm);border-bottom:1px solid var(--hair-soft);position:relative;overflow:hidden}
.page-hero .container{padding-top:64px;padding-bottom:64px;position:relative;z-index:2;text-align:center}
.page-hero .eyebrow{font-size:12px;letter-spacing:0.32em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:16px}
.page-hero .gold-line{width:56px;height:2px;background:var(--gold);margin:0 auto 24px}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:46px;line-height:1.12;margin:0 0 16px;color:var(--ink);letter-spacing:-0.01em}
.page-hero p{font-size:15px;color:var(--ink-2);max-width:560px;margin:0 auto;line-height:1.65}
.page-hero::after{content:'';position:absolute;right:-80px;top:-60px;width:320px;height:320px;border-radius:50%;border:1px solid var(--gold-line);opacity:.4;z-index:1}
.page-hero::before{content:'';position:absolute;left:-90px;bottom:-90px;width:240px;height:240px;border-radius:50%;background:rgba(198,168,118,.10);z-index:1}

/* Shared section eyebrow / headings */
.section-eyebrow{text-align:center;font-size:12px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:56px}

/* ---------- FOOTER ---------- */
.footer{background:var(--cream);padding:40px 0 50px;border-top:1px solid var(--hair-soft)}
.footer-grid{display:grid;grid-template-columns:1.05fr 1.1fr 1.05fr 1.1fr;gap:36px}
.fcol h4{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);font-weight:600;margin:0 0 18px}
.fcol .row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:13px;color:var(--ink-2);line-height:1.45}
.fcol .row svg{width:15px;height:15px;color:var(--teal);flex-shrink:0;margin-top:2px}
.fcol .row a:hover{color:var(--teal)}
.socials{display:flex;gap:10px;margin-top:16px}
.socials a{width:30px;height:30px;border-radius:50%;border:1px solid var(--ink);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background .15s ease,color .15s ease,border-color .15s ease}
.socials a:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.socials a svg{width:13px;height:13px}

.hours-table{width:100%;border-collapse:collapse;font-size:13px}
.hours-table td{padding:4px 0;color:var(--ink-2);font-family:'Inter',sans-serif}
.hours-table td.day{width:90px}
.hours-table td.time{font-variant-numeric:tabular-nums;color:var(--muted)}
.hours-note{font-size:12px;color:var(--muted);margin-top:10px;font-style:italic}

.footer .map{border-radius:6px;overflow:hidden;height:158px;background:#DCE5D4;border:1px solid var(--hair-soft);position:relative}
.footer .map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.2) contrast(.95)}

.book-card{background:var(--cream-soft);border:1px solid var(--gold);border-radius:4px;padding:28px 24px 24px;text-align:center}
.book-card .t1{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:12px}
.book-card .t2{font-size:13px;color:var(--ink-2);line-height:1.5;margin-bottom:18px}
.book-card .btn{width:100%}
.book-card .via{margin-top:12px;font-size:11px;color:var(--muted);font-style:italic}
.book-card .via a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}

/* ---------- COPYRIGHT BAR ---------- */
.copy-bar{background:var(--teal-darker);color:#C9C2B0;padding:14px 0;font-size:12px}
.copy-bar-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap}
.copy-bar .sep{opacity:.5}
.copy-bar a:hover{color:#fff}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:861px) and (max-width:1100px){
  .nav{gap:14px;padding:0 22px}
  .logo{padding-right:8px}
  .logo .mark{width:36px;height:36px}
  .logo .mark svg{width:30px;height:30px}
  .logo .wordmark .a{font-size:13px}
  .logo .wordmark .b{font-size:8px;letter-spacing:0.26em}
  nav.primary{gap:18px;margin-left:6px}
  nav.primary > a,.has-drop > a{font-size:11.5px;letter-spacing:0.10em}
  .btn{padding:11px 18px;font-size:11px;letter-spacing:0.12em}
  .container{padding:0 22px}
  .page-hero h1{font-size:38px}
  .footer-grid{gap:26px}
  .fcol h4{font-size:10.5px}
  .fcol .row{font-size:12.5px}
  .hours-table{font-size:12.5px}
  .book-card{padding:22px 18px 20px}
  .footer .map{height:140px}
}

/* TABLET */
@media (max-width:860px){
  .nav{height:58px;gap:16px;padding:0 20px}
  .container{padding:0 20px}
  .logo .wordmark .a{font-size:13px}
  .logo .wordmark .b{font-size:8px;letter-spacing:0.28em}
  .logo .mark{width:36px;height:36px}
  .logo .mark svg{width:30px;height:30px}

  nav.primary{
    position:absolute;top:58px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream-soft);padding:0;margin:0;
    max-height:0;overflow:hidden;transition:max-height .28s ease,padding .28s ease;z-index:90;
  }
  nav.primary.open{max-height:720px;padding:12px 0 20px;border-bottom:1px solid var(--hair-soft);box-shadow:0 8px 20px rgba(0,0,0,.06)}
  nav.primary > a,.has-drop > a{padding:14px 24px;border-bottom:1px solid rgba(0,0,0,.04);letter-spacing:0.12em;width:100%}
  nav.primary a.active::after{display:none}
  .has-drop{flex-direction:column;align-items:stretch;width:100%}
  .has-drop .caret{display:none}
  .dropdown{
    position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;box-shadow:none;border:0;border-radius:0;
    min-width:0;padding:0;background:var(--cream-card)
  }
  .dropdown::before{display:none}
  .dropdown a{padding:11px 24px 11px 40px;font-size:11px}
  nav.primary a.nav-cta-mobile{
    display:flex !important;color:#fff;background:var(--teal);
    border-bottom:0;width:auto;border-radius:4px;
    margin:16px 24px 4px;padding:15px 20px;letter-spacing:0.14em;justify-content:center;
  }
  nav.primary a.nav-cta-mobile:hover{background:var(--teal-hover);color:#fff}
  .nav-cta{display:none}
  .hamburger{display:flex}

  .page-hero .container{padding-top:48px;padding-bottom:48px}
  .page-hero h1{font-size:34px}

  .footer{padding:40px 0 40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px 28px}
  .copy-bar-inner{gap:10px 16px;font-size:11.5px}
}

/* MOBILE */
@media (max-width:640px){
  .container{padding:0 18px}
  .nav{padding:0 18px;gap:10px}
  .page-hero .container{padding-top:40px;padding-bottom:40px}
  .page-hero h1{font-size:28px}
  .page-hero h1 br{display:none}
  .page-hero p{font-size:14px}
  .section-eyebrow{margin-bottom:40px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer .map{height:200px}
  .copy-bar{padding:14px 18px}
  .copy-bar-inner{flex-direction:column;gap:4px;text-align:center}
  .copy-bar .sep{display:none}
}

/* ============ ANIMASJONER & DEKOR (undersider) ============ */
@keyframes revUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: no-preference){
  /* Page-hero entré */
  html.reveal-on .page-hero .eyebrow,
  html.reveal-on .page-hero .gold-line,
  html.reveal-on .page-hero h1,
  html.reveal-on .page-hero p{opacity:0;animation:revUp .85s cubic-bezier(.22,.61,.36,1) forwards}
  html.reveal-on .page-hero .eyebrow{animation-delay:.05s}
  html.reveal-on .page-hero .gold-line{animation-delay:.16s}
  html.reveal-on .page-hero h1{animation-delay:.26s}
  html.reveal-on .page-hero p{animation-delay:.4s}
  /* Innhold som tones inn ved scroll (.is-in legges til av main.js) */
  html.reveal-on .stat,
  html.reveal-on .value,
  html.reveal-on .ocard,
  html.reveal-on .ccard,
  html.reveal-on .treat,
  html.reveal-on .story-inner,
  html.reveal-on .standards-inner,
  html.reveal-on .gallery image-slot,
  html.reveal-on .info-split,
  html.reveal-on .directions{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
  html.reveal-on .is-in{opacity:1 !important;transform:none !important}
}
/* Hover-løft på kort + zoom i galleri */
.ocard:hover,.ccard:hover,.value:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(20,48,46,.12)}
.gallery image-slot img{transition:transform .55s ease}
.gallery image-slot:hover img{transform:scale(1.06)}
.btn-primary:hover{box-shadow:0 12px 26px rgba(20,48,46,.22)}
