/* =====================================================================
     DESIGNTOKENS
     ===================================================================== */
  :root{
    color-scheme: light;
    --bone:#F7F3EE;        /* varm off-white – hovedlerret */
    --paper:#FCFAF6;       /* litt lysere – kort/kontrast    */
    --ink:#1F1B1A;         /* djup blekksort – tekst         */
    --stone:#6B625C;       /* varm grå – sekundærtekst       */
    --line:#DCD0C0;        /* hårline                        */
    --forest:#6E2A3C;      /* DYP SKOGGRØNN – eneste aksent  */
    --forest-2:#511E2C;    /* lysere grønn – hover           */
    --forest-deep:#3E1622; /* mørk grønn – fullbredde-seksjon*/

    --gold:#C6A35A; --gold-soft:#E3CFA0;
    --display:"Playfair Display", Georgia, serif;
    --body:"Inter", system-ui, -apple-system, sans-serif;

    --maxw:1140px;
    /* generøs, responsiv seksjonshøyde – luksus = luft */
    --pad-y:clamp(84px, 13vw, 168px);
    --gutter:clamp(22px, 5vw, 60px);
  }

  /* =====================================================================
     BASIS / RESET
     ===================================================================== */
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--bone);
    color:var(--ink);
    font-family:var(--body);
    font-size:clamp(1rem, 0.96rem + 0.2vw, 1.1rem);
    line-height:1.75;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;}
  h1,h2,h3{font-family:var(--display);font-weight:500;margin:0;line-height:1.06;letter-spacing:-.01em;font-optical-sizing:auto;}
  p{margin:0;}
  ::selection{background:var(--forest);color:var(--bone);}

  .wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
  .section{padding-block:var(--pad-y);}

  /* Etikett i kapitéler – strukturelt signal, ikke pynt */
  .kicker{
    font-family:var(--body);font-size:.72rem;font-weight:600;
    letter-spacing:.26em;text-transform:uppercase;color:var(--forest);
    display:inline-flex;align-items:center;gap:.85em;
  }
  .kicker::before{content:"";width:30px;height:1px;background:var(--gold);display:inline-block;}
  .kicker.center{justify-content:center;}

  /* =====================================================================
     KNAPPER  (én gjennomgående primær-CTA)
     ===================================================================== */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.6em;
    font-family:var(--body);font-weight:500;font-size:.98rem;letter-spacing:.01em;
    padding:1.05em 2em;border:1px solid var(--forest);border-radius:2px;
    cursor:pointer;transition:background .35s ease, color .35s ease, transform .35s ease;
    white-space:nowrap;
  }
  .btn-primary{background:var(--forest);color:var(--bone);}
  .btn-primary:hover{background:var(--forest-2);border-color:var(--forest-2);transform:translateY(-2px);}
  .btn-ghost{background:transparent;color:var(--forest);}
  .btn-ghost:hover{background:var(--forest);color:var(--bone);transform:translateY(-2px);}
  .btn .arrow{transition:transform .35s ease;}
  .btn:hover .arrow{transform:translateX(4px);}
  /* lys variant til mørk grønn bakgrunn */
  .on-dark .btn-primary{background:var(--bone);color:var(--forest-deep);border-color:var(--bone);}
  .on-dark .btn-primary:hover{background:#fff;border-color:#fff;}

  :focus-visible{outline:2px solid var(--forest);outline-offset:3px;}
  .on-dark :focus-visible{outline-color:var(--bone);}

  /* tekstlenke med voksende understrek */
  .tlink{color:var(--forest);font-weight:500;position:relative;}
  .tlink::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:currentColor;transition:right .3s ease;}
  .tlink:hover::after{right:0;}

  /* =====================================================================
     TOPPLINJE
     ===================================================================== */
  .topbar{
    position:sticky;top:0;z-index:50;
    background:rgba(244,243,240,.82);backdrop-filter:blur(10px);
    border-bottom:1px solid transparent;transition:border-color .3s ease;
  }
  .topbar.scrolled{border-bottom-color:var(--line);}
  .topbar .row{display:flex;align-items:center;justify-content:space-between;height:74px;}
  .brand{font-family:var(--display);font-size:1.5rem;font-weight:600;letter-spacing:-.01em;display:inline-flex;align-items:baseline;gap:.5em;}
  .brand small{font-family:var(--body);font-size:.6rem;letter-spacing:.34em;font-weight:600;color:var(--stone);text-transform:uppercase;}
  .nav-desktop{display:none;gap:34px;}
  .nav-desktop a{font-size:.92rem;color:var(--ink);opacity:.75;transition:opacity .25s;}
  .nav-desktop a:hover{opacity:1;}
  .topbar .btn{padding:.7em 1.3em;font-size:.88rem;}

  /* =====================================================================
     1 · HERO  (type-drevet, mye luft – signaturens rolige motstykke)
     ===================================================================== */
  .hero{padding-block:clamp(72px,12vw,150px) var(--pad-y);}
  .hero-inner{display:block;}
  .hero-media{margin-top:clamp(34px,7vw,40px);}
  .hero-frame{margin:0;border-radius:3px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 60px -34px rgba(31,27,26,.5), 0 0 0 1px var(--gold-soft);}
  .hero-frame img{width:100%;height:100%;object-fit:cover;display:block;}
  .editorial-band{margin:0;}
  .editorial-band img{width:100%;height:clamp(300px,48vh,540px);object-fit:cover;display:block;}
  .hero h1{
    font-size:clamp(2.9rem, 7.5vw, 6.1rem);
    letter-spacing:-.025em;line-height:1.02;
    margin:.42em 0 0;max-width:16ch;
  }
  .hero h1 em{font-style:italic;color:var(--forest);font-weight:400;}
  .hero .sub{
    font-size:clamp(1.08rem,1rem + .4vw,1.3rem);color:var(--stone);
    max-width:46ch;margin:1.6em 0 0;line-height:1.65;
  }
  .hero-cta{display:flex;flex-wrap:wrap;align-items:center;gap:18px 26px;margin-top:2.6em;}
  .rating{display:inline-flex;align-items:center;gap:.6em;font-size:.92rem;color:var(--stone);}
  .rating .stars{color:var(--gold);letter-spacing:2px;}
  .rating b{color:var(--ink);font-weight:600;}

  /* =====================================================================
     2 · PROBLEMET
     ===================================================================== */
  .problem{border-top:1px solid var(--line);}
  .lede{
    font-family:var(--display);font-weight:400;
    font-size:clamp(1.5rem,1.2rem + 1.6vw,2.4rem);line-height:1.3;
    max-width:20ch;margin:.7em 0 0;letter-spacing:-.01em;
  }
  .problem .body{max-width:54ch;margin-top:1.4em;color:var(--stone);}
  .two-col{display:grid;gap:clamp(28px,5vw,72px);}

  /* =====================================================================
     3 · LØSNINGEN  (SIGNATUR: én dramatisk fullbredde grønn seksjon)
     ===================================================================== */
  .solution{background:#EBE2D6;color:var(--ink);text-align:center;border-block:1px solid var(--gold-soft);}
  .solution .kicker{color:var(--forest);}
  .solution .kicker::before{background:var(--gold);}
  .solution h2{
    color:var(--ink);font-weight:400;
    font-size:clamp(2rem,1.4rem + 3vw,3.6rem);line-height:1.16;
    max-width:18ch;margin:.5em auto .55em;letter-spacing:-.015em;
  }
  .solution h2 em{font-style:italic;color:var(--forest);} /* varm champagne-tone kun her */
  .solution .body{max-width:52ch;margin:0 auto;color:var(--stone);font-size:1.12rem;line-height:1.75;}
  .solution .sign{
    margin-top:2.4em;font-family:var(--display);font-style:italic;
    font-size:1.15rem;color:var(--forest);
  }

  /* =====================================================================
     4 · FORDELER
     ===================================================================== */
  .benefits .head{max-width:40ch;margin-bottom:clamp(40px,6vw,72px);}
  .benefits h2{font-size:clamp(1.9rem,1.4rem + 2vw,3rem);margin-top:.4em;}
  .grid-3{display:grid;gap:clamp(34px,4vw,52px);}
  .benefit{}
  .benefit .ico{width:40px;height:40px;color:var(--forest);}
  .benefit .ico svg{width:100%;height:100%;stroke:currentColor;stroke-width:1.4;fill:none;}
  .benefit h3{font-size:1.45rem;margin:1.1em 0 0;}
  .benefit .num{font-family:var(--body);font-size:.72rem;letter-spacing:.2em;color:var(--stone);}
  .benefit p{margin-top:.7em;color:var(--stone);font-size:1rem;}
  .benefit .rule{width:32px;height:1px;background:var(--line);margin:1.3em 0 0;}

  /* =====================================================================
     5 · SOSIALT BEVIS
     ===================================================================== */
  .proof{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
  .proof .head{display:flex;flex-direction:column;gap:.9em;margin-bottom:clamp(40px,5vw,64px);}
  .proof .summary{font-family:var(--display);font-size:clamp(1.4rem,1.1rem + 1.3vw,2rem);font-weight:400;letter-spacing:-.01em;}
  .proof .summary b{color:var(--forest);}
  .quotes{display:grid;gap:clamp(30px,4vw,44px);}
  .quote{}
  .quote .q-stars{color:var(--gold);letter-spacing:2px;font-size:.95rem;}
  .quote blockquote{
    margin:.9em 0 0;font-family:var(--display);font-weight:400;
    font-size:1.32rem;line-height:1.45;letter-spacing:-.01em;
  }
  .quote .who{margin-top:1.1em;font-size:.86rem;color:var(--stone);letter-spacing:.02em;}
  .quote .who b{color:var(--ink);font-weight:600;}

  /* =====================================================================
     6 · PRIS / VERDI
     ===================================================================== */
  .pricing .panel{
    background:var(--paper);border:1px solid var(--line);border-radius:3px;
    padding:clamp(34px,5vw,64px);
  }
  .pricing .grid{display:grid;gap:clamp(36px,5vw,64px);align-items:start;}
  .pricing h2{font-size:clamp(1.9rem,1.4rem + 2vw,3rem);margin-top:.4em;}
  .pricing .incl{color:var(--stone);margin-top:1.3em;max-width:42ch;}
  .pricelist{list-style:none;margin:0;padding:0;}
  .pricelist li{
    display:flex;justify-content:space-between;align-items:baseline;gap:18px;
    padding:16px 0;border-top:1px solid var(--line);
  }
  .pricelist li:first-child{border-top:none;}
  .pricelist .svc{font-weight:500;}
  .pricelist .amt{font-family:var(--display);font-size:1.2rem;color:var(--forest);white-space:nowrap;}
  .pricing .note{margin-top:1.6em;font-size:.86rem;color:var(--stone);}
  .pricing .cta-wrap{margin-top:2em;}

  /* =====================================================================
     7 · AVSLUTTENDE CTA + SALONGVALG
     ===================================================================== */
  .closing{text-align:center;}
  .closing h2{font-size:clamp(2.2rem,1.6rem + 3vw,4rem);max-width:16ch;margin:.45em auto 0;letter-spacing:-.02em;}
  .closing h2 em{font-style:italic;color:var(--forest);font-weight:400;}
  .closing .sub{color:var(--stone);max-width:44ch;margin:1.4em auto 0;}
  .salons{display:grid;gap:18px;margin-top:clamp(44px,6vw,68px);text-align:left;}
  .salon{
    display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
    background:var(--paper);border:1px solid var(--line);border-radius:3px;
    padding:24px clamp(22px,3vw,32px);transition:border-color .3s ease, transform .3s ease;
  }
  .salon:hover{border-color:var(--forest);transform:translateY(-2px);}
  .salon .s-name{font-family:var(--display);font-size:1.35rem;}
  .salon .s-addr{font-size:.9rem;color:var(--stone);margin-top:.25em;}
  .salon .s-go{font-weight:500;color:var(--forest);display:inline-flex;align-items:center;gap:.5em;}
  .salon .s-go .arrow{transition:transform .3s ease;}
  .salon:hover .s-go .arrow{transform:translateX(4px);}

  /* =====================================================================
     8 · FOOTER
     ===================================================================== */
  footer{background:var(--paper);color:var(--stone);border-top:1px solid var(--line);padding-block:clamp(56px,7vw,84px) 40px;}
  .foot-grid{display:grid;gap:clamp(34px,5vw,56px);}
  footer .brand{color:var(--ink);}
  footer .brand small{color:var(--stone);}
  footer .tagline{margin-top:1em;max-width:30ch;font-size:.95rem;line-height:1.6;}
  footer h4{font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);margin:0 0 1.2em;}
  footer .fcol a, footer .fcol p{display:block;color:var(--stone);font-size:.95rem;padding:4px 0;margin:0;}
  footer .fcol a:hover{color:var(--forest);}
  .foot-bottom{
    margin-top:clamp(44px,6vw,64px);padding-top:26px;border-top:1px solid var(--line);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
    font-size:.82rem;color:var(--stone);
  }

  /* =====================================================================
     SCROLL-ANIMASJON  (myk fade + oppglidning)
     ===================================================================== */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.22,.61,.36,1), transform .9s cubic-bezier(.22,.61,.36,1);}
  .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}
  .reveal.d2{transition-delay:.16s;}
  .reveal.d3{transition-delay:.24s;}

  /* Hero-sekvens ved innlasting */
  .seq{opacity:0;transform:translateY(20px);animation:rise .95s cubic-bezier(.22,.61,.36,1) forwards;}
  .seq.s1{animation-delay:.05s;} .seq.s2{animation-delay:.18s;}
  .seq.s3{animation-delay:.31s;} .seq.s4{animation-delay:.44s;}
  @keyframes rise{to{opacity:1;transform:none;}}

  /* =====================================================================
     RESPONSIVT  (mobil-først → opp)
     ===================================================================== */
  @media (min-width:760px){
    .nav-desktop{display:flex;}
    .hero-inner{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(40px,5vw,72px);align-items:center;}
    .hero-media{margin-top:0;}
    .two-col{grid-template-columns:0.85fr 1.15fr;align-items:start;}
    .grid-3{grid-template-columns:repeat(3,1fr);}
    .quotes{grid-template-columns:repeat(3,1fr);}
    .pricing .grid{grid-template-columns:1fr 1fr;}
    .foot-grid{grid-template-columns:1.6fr 1fr 1fr;}
    .salons{grid-template-columns:1fr;}
  }
  @media (min-width:1024px){
    .proof .head{flex-direction:row;align-items:flex-end;justify-content:space-between;}
    .proof .summary{max-width:24ch;}
  }

  @media (prefers-reduced-motion:reduce){
    html{scroll-behavior:auto;}
    .reveal,.seq{opacity:1 !important;transform:none !important;transition:none !important;animation:none !important;}
    .btn:hover,.btn-ghost:hover,.salon:hover{transform:none !important;}
  }

  /* ===================== UTVIDET INNHOLD ===================== */
  .btn-sm{padding:.72em 1.25em;font-size:.86rem;}
  .sp-head{max-width:46ch;margin-bottom:clamp(36px,5vw,60px);}
  .sp-head h2{font-size:clamp(1.9rem,1.4rem + 2vw,3rem);margin-top:.4em;}
  .sp-head p{color:var(--stone);margin-top:1em;}

  /* Faner */
  .tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(28px,4vw,42px);}
  .tab{font-family:var(--body);font-size:.95rem;font-weight:500;color:var(--stone);background:transparent;border:1px solid var(--line);border-radius:2px;padding:.7em 1.3em;cursor:pointer;transition:background .25s,color .25s,border-color .25s;}
  .tab:hover{border-color:var(--forest);color:var(--ink);}
  .tab.is-active{background:var(--forest);color:var(--paper);border-color:var(--forest);}
  .tab-panel[hidden]{display:none;}
  .price-cols{display:grid;gap:clamp(30px,4vw,52px);}
  .price-group h3{font-family:var(--display);font-size:1.3rem;font-weight:500;margin:0 0 .55em;padding-bottom:.5em;border-bottom:1px solid var(--gold-soft);}
  .sp-note{margin-top:1.8em;font-size:.85rem;color:var(--stone);}
  .sp-cta{margin-top:2em;}

  /* Frisører */
  .team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,3vw,38px);}
  .stylist{margin:0;text-align:center;}
  .portrait{aspect-ratio:1;border-radius:3px;overflow:hidden;background:#EBE2D6;box-shadow:0 18px 36px -28px rgba(31,27,26,.5),0 0 0 1px var(--gold-soft);display:flex;align-items:center;justify-content:center;}
  .portrait img{width:100%;height:100%;object-fit:cover;display:block;}
  .portrait.mono{font-family:var(--display);font-size:2.4rem;color:var(--forest);background:#EFE6DE;}
  .stylist figcaption{margin-top:1em;display:flex;flex-direction:column;gap:.18em;}
  .st-name{font-family:var(--display);font-size:1.18rem;}
  .st-role{font-size:.84rem;color:var(--stone);line-height:1.4;}
  .st-salon{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--forest);margin-top:.35em;}

  /* Finn oss */
  .loc-grid{display:grid;gap:clamp(24px,3vw,30px);}
  .loc-card{background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:clamp(22px,3vw,30px);}
  .loc-card h3{font-family:var(--display);font-size:1.4rem;font-weight:500;}
  .loc-addr{margin-top:.6em;}
  .loc-addr a{color:var(--forest);font-weight:500;}
  .loc-phone{margin-top:.35em;font-size:.92rem;color:var(--stone);}
  .loc-phone a{color:var(--ink);}
  .map{margin-top:1.1em;border-radius:3px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;background:#EBE2D6;}
  .map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.25) contrast(.96);}
  .hours{margin:1.1em 0 0;}
  .hours dl{display:grid;grid-template-columns:auto 1fr;gap:5px 16px;margin:0;font-size:.9rem;}
  .hours dt{color:var(--stone);}
  .hours dd{margin:0;text-align:right;font-variant-numeric:tabular-nums;}
  .hours dd.closed{color:var(--stone);}
  .loc-actions{margin-top:1.3em;display:flex;gap:10px;}
  .loc-actions .btn{flex:1;}

  /* Gavekort */
  .giftcard{background:#EFE6DE;}
  .giftcard-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;}
  .giftcard-inner h2{font-size:clamp(1.7rem,1.3rem + 1.6vw,2.6rem);margin-top:.3em;}
  .giftcard-inner p{color:var(--stone);margin-top:.7em;max-width:48ch;}

  /* FAQ */
  .faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
  .faq-item{background:var(--paper);border:1px solid var(--line);border-radius:3px;overflow:hidden;}
  .faq-item summary{cursor:pointer;list-style:none;padding:18px 20px;font-family:var(--display);font-size:1.1rem;font-weight:500;display:flex;justify-content:space-between;align-items:center;gap:16px;}
  .faq-item summary::-webkit-details-marker{display:none;}
  .faq-item summary::after{content:"+";font-size:1.5rem;color:var(--forest);transition:transform .25s;line-height:1;flex:none;}
  .faq-item[open] summary::after{transform:rotate(45deg);}
  .faq-a{padding:0 20px 18px;color:var(--stone);line-height:1.6;}

  /* Popup */
  .modal[hidden]{display:none;}
  .modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;}
  .modal-overlay{position:absolute;inset:0;background:rgba(31,27,26,.5);backdrop-filter:blur(3px);}
  .modal-card{position:relative;background:var(--paper);border-radius:4px;padding:30px 26px 26px;max-width:440px;width:100%;box-shadow:0 40px 80px -30px rgba(31,27,26,.55);border-top:3px solid var(--gold);animation:pop .25s ease;}
  .modal-card .kicker{margin-bottom:.1em;}
  .modal-x{position:absolute;top:10px;right:12px;width:38px;height:38px;background:none;border:none;font-size:1.7rem;line-height:1;color:var(--stone);cursor:pointer;border-radius:4px;}
  .modal-x:hover{background:#EFE6DE;color:var(--ink);}
  .modal-card h3{font-family:var(--display);font-size:1.5rem;font-weight:500;margin:.2em 0 0;}
  .modal-sub{color:var(--stone);font-size:.92rem;margin:.5em 0 1.2em;}
  .modal-opts{display:flex;flex-direction:column;gap:10px;}
  .modal-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;border:1px solid var(--line);border-radius:3px;}
  .mo-name{font-weight:600;display:block;}
  .mo-city{font-size:.8rem;color:var(--stone);display:block;margin-top:1px;}
  .mo-actions{display:flex;gap:8px;flex:none;}
  .mo-ring,.mo-book{font-size:.86rem;font-weight:500;padding:.55em .95em;border-radius:2px;white-space:nowrap;transition:background .2s,border-color .2s,color .2s;}
  .mo-ring{border:1px solid var(--line);color:var(--forest);}
  .mo-ring:hover{border-color:var(--forest);}
  .mo-book{background:var(--forest);color:var(--paper);}
  .mo-book:hover{background:var(--forest-2);}
  @keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion:reduce){.modal-card{animation:none;}}

  /* Responsivt for nye seksjoner */
  @media (min-width:760px){
    .price-cols{grid-template-columns:repeat(3,1fr);}
    .team-grid{grid-template-columns:repeat(3,1fr);}
    .loc-grid{grid-template-columns:repeat(3,1fr);}
  }
  [id]{scroll-margin-top:86px;}

  /* Finn oss – solo (salongside) */
  .loc-solo{display:grid;gap:clamp(24px,4vw,40px);align-items:start;}
  .loc-info .loc-addr a{color:var(--forest);font-weight:500;}
  .loc-info .loc-phone{margin-top:.35em;font-size:.95rem;color:var(--stone);}
  .loc-info .loc-phone a{color:var(--ink);}
  .loc-card h3 a, .loc-info h3 a{color:inherit;}
  .loc-card h3 a:hover{color:var(--forest);}
  @media (min-width:760px){ .loc-solo{grid-template-columns:1fr 1.1fr;} }

  .loc-more{display:inline-flex;align-items:center;gap:.4em;margin-top:1.1em;font-weight:500;color:var(--forest);font-size:.93rem;transition:gap .25s ease;}
  .loc-more:hover{gap:.75em;}

  .brand-logo{height:40px;width:auto;display:block;}
  .topbar .brand{align-items:center;}
  .brand-logo--foot{height:52px;}

  /* Salongkort med bilde (finn oss) */
  .salon-grid{display:grid;gap:clamp(22px,3vw,28px);}
  .salon-card{background:var(--paper);border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 44px -30px rgba(31,27,26,.45);}
  .sc-img{aspect-ratio:3/2;overflow:hidden;background:#EBE2D6;}
  .sc-img img{width:100%;height:100%;object-fit:cover;transition:transform .65s cubic-bezier(.2,.7,.2,1);}
  .salon-card:hover .sc-img img{transform:scale(1.05);}
  .sc-body{padding:clamp(22px,3vw,28px);display:flex;flex-direction:column;flex:1;}
  .sc-body h3{font-family:var(--display);font-size:1.5rem;font-weight:500;}
  .sc-meta{display:flex;flex-direction:column;gap:9px;margin-top:14px;font-size:.92rem;color:var(--stone);}
  .sc-meta span{display:flex;align-items:flex-start;gap:.6em;}
  .sc-meta svg{width:17px;height:17px;flex:none;color:var(--forest);margin-top:2px;}
  .sc-meta a{color:var(--ink);}
  .sc-meta a:hover{color:var(--forest);}
  .sc-hours{margin-top:18px;border-top:1px solid var(--line);padding-top:16px;}
  .sc-hours-title{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--forest);margin-bottom:10px;}
  .sc-hours dl{display:grid;grid-template-columns:auto 1fr;gap:5px 16px;margin:0;font-size:.9rem;}
  .sc-hours dt{color:var(--stone);}
  .sc-hours dd{margin:0;text-align:right;font-variant-numeric:tabular-nums;}
  .sc-hours dd.closed{color:var(--stone);}
  .salon-card .loc-more{margin-top:18px;}
  .sc-actions{margin-top:auto;padding-top:18px;display:flex;gap:10px;}
  .sc-actions .btn{flex:1;}
  @media (min-width:760px){ .salon-grid{grid-template-columns:repeat(3,1fr);} }

  /* Toppmeny-handlinger: ring-knapp + mobilmeny */
  .topbar-actions{display:flex;align-items:center;gap:10px;}
  .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--forest);cursor:pointer;transition:background .2s,border-color .2s;text-decoration:none;}
  .btn-icon:hover{background:var(--paper);border-color:var(--forest);}
  .btn-icon svg{width:19px;height:19px;}
  .nav-book{display:none;}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:none;background:transparent;color:var(--ink);cursor:pointer;padding:0;}
  .menu-toggle svg{width:24px;height:24px;}
  .mobile-nav{display:none;flex-direction:column;padding:6px clamp(22px,5vw,60px) 22px;border-top:1px solid var(--line);background:var(--bone);}
  .mobile-nav.open{display:flex;}
  .mobile-nav a{padding:14px 2px;font-size:1.05rem;color:var(--ink);border-bottom:1px solid var(--line);}
  .mobile-nav a:last-of-type{border-bottom:none;}
  .mobile-nav .btn{margin-top:14px;width:100%;}
  @media (min-width:760px){
    .nav-book{display:inline-flex;}
    .menu-toggle{display:none;}
    .mobile-nav{display:none !important;}
  }
