/* =========================================================
   Sabine Appel — Indretningsarkitekt
   Design: warm, editorial minimalism (Nordic)
   ========================================================= */

:root{
  --bg:#f4f1ea;          /* warm off-white canvas */
  --bg-2:#ebe5da;        /* slightly deeper section */
  --ink:#2a2520;         /* near-black, warm */
  --muted:#837a6c;       /* muted brown-grey */
  --line:rgba(42,37,32,.16);
  --accent:#6d6650;      /* subtle olive/stone */
  --white:#fff;

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Jost", "Helvetica Neue", Arial, sans-serif;

  --wrap:1280px;
  --pad:clamp(1.25rem, 5vw, 4rem);
  --section-y:clamp(4.5rem, 10vw, 9rem);
  --header-h:74px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:var(--header-h); -webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:clamp(1rem,.96rem + .25vw,1.075rem);
  line-height:1.75;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- Typographic helpers ---------- */
.display{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.04;
  letter-spacing:.005em;
  font-size:clamp(2.2rem,1.4rem + 3.4vw,4rem);
  margin:0;
}
.overline{
  font-size:.74rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:400;
  color:var(--muted);
  margin:0 0 1.4rem;
}
.overline span{color:var(--ink)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;
  height:var(--header-h);
  display:flex;align-items:center;
  transition:background .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header .nav{
  width:100%;max-width:var(--wrap);margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:var(--pad);
}
.wordmark{
  font-size:1.04rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  color:var(--white);transition:color .4s var(--ease);white-space:nowrap;
}
.nav-links{display:flex;gap:clamp(1.25rem,3vw,2.75rem)}
.nav-links a{
  position:relative;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.86);transition:color .3s var(--ease);padding:.2rem 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:center;
  transition:transform .35s var(--ease);
}
.nav-links a:hover::after,.nav-links a.is-active::after{transform:scaleX(1)}
.nav-links a.is-active{color:var(--white)}

/* Header solid state after scroll */
.site-header.is-scrolled{
  background:rgba(244,241,234,.9);
  -webkit-backdrop-filter:saturate(120%) blur(10px);
  backdrop-filter:saturate(120%) blur(10px);
  box-shadow:0 1px 0 var(--line);
}
.site-header.is-scrolled .wordmark{color:var(--ink)}
.site-header.is-scrolled .nav-links a{color:var(--muted)}
.site-header.is-scrolled .nav-links a.is-active{color:var(--ink)}

/* Hamburger */
.nav-toggle{
  display:none;width:42px;height:42px;border:0;background:none;cursor:pointer;
  padding:10px 8px;margin-right:-8px;
}
.nav-toggle span{display:block;height:1.5px;background:var(--white);margin:5px 0;transition:.35s var(--ease)}
.site-header.is-scrolled .nav-toggle span{background:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;height:100svh;min-height:540px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero__img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.04);animation:heroIn 1.8s var(--ease) both;will-change:transform;
}
@keyframes heroIn{from{transform:scale(1.12);opacity:.5}to{transform:scale(1.04);opacity:1}}
/* Layered veil: soft radial behind the text + gentle top/bottom gradient — keeps a light hero airy yet legible */
.hero__veil{position:absolute;inset:0;background:
  radial-gradient(ellipse 62% 48% at 50% 47%, rgba(28,22,16,.42), rgba(28,22,16,0) 72%),
  linear-gradient(180deg, rgba(28,22,16,.30) 0%, rgba(28,22,16,.06) 32%, rgba(28,22,16,.40) 100%)}
.hero__content{position:relative;text-align:center;color:var(--white);padding:1.5rem;
  animation:heroText 1.3s .35s var(--ease) both;text-shadow:0 1px 26px rgba(20,15,10,.32)}
.hero__name{font-family:var(--serif);font-weight:400;letter-spacing:.02em;line-height:1.02;margin:0;
  font-size:clamp(2.6rem,1.2rem + 6.6vw,7rem)}
.hero__title{margin:1rem 0 0;font-size:clamp(.78rem,.68rem + .4vw,1rem);letter-spacing:.4em;text-transform:uppercase;font-weight:300;padding-left:.4em}
.hero__tag{margin:1.1rem 0 0;font-size:clamp(.76rem,.72rem + .2vw,.85rem);letter-spacing:.12em;color:rgba(255,255,255,.86)}
@keyframes heroText{from{opacity:0;transform:translateY(26px);letter-spacing:.12em}to{opacity:1;transform:none}}
.hero__cue{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);width:26px;height:42px;
  border:1px solid rgba(255,255,255,.6);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.hero__cue span{width:2px;height:8px;background:rgba(255,255,255,.85);border-radius:2px;animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(10px)}}

/* ---------- Sections ---------- */
.section{padding-block:var(--section-y)}
.section-head{margin-bottom:clamp(2rem,4vw,3.5rem);max-width:40rem}

/* ---------- 01 Om ---------- */
.om{background:var(--bg)}
.om__grid{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:clamp(2rem,6vw,6rem);align-items:center}
.om__media{margin:0;overflow:hidden}
.om__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4;object-position:50% 18%}
.om__text .display{margin-bottom:1.6rem}
.om__text p{margin:0 0 1.1rem;max-width:36rem;color:#3b352e}
.om__services{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem .5rem;margin:2rem 0 0;padding:0}
.om__services li{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:.5rem .95rem}

/* ---------- 02 Projekter ---------- */
.projects{background:var(--bg-2)}
.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.2vw,2rem)}
.project-card{
  display:block;border:0;background:none;padding:0;margin:0;cursor:pointer;text-align:left;width:100%;
  color:inherit;
}
.project-card__media{display:block;position:relative;overflow:hidden;background:#ddd6c9}
.project-card__media img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 1.2s var(--ease),filter .6s var(--ease)}
.project-card__media::after{
  content:"Se projekt";position:absolute;left:0;right:0;bottom:0;
  padding:1.4rem 1rem 1.1rem;color:#fff;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;text-align:center;
  background:linear-gradient(transparent,rgba(24,18,12,.6));
  opacity:0;transform:translateY(10px);transition:opacity .5s var(--ease),transform .5s var(--ease);
  pointer-events:none;
}
.project-card:hover .project-card__media img,
.project-card:focus-visible .project-card__media img{transform:scale(1.05)}
.project-card:hover .project-card__media::after,
.project-card:focus-visible .project-card__media::after{opacity:1;transform:none}
/* Touch devices have no hover — show the "Se projekt" cue permanently */
@media (hover: none){
  .project-card__media::after{opacity:1;transform:none}
}
.project-card__meta{display:flex;flex-direction:column;gap:.25rem;padding:1rem .1rem 0}
.project-card__title{font-family:var(--serif);font-size:1.5rem;line-height:1.1}
.project-card__cat{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* ---------- 03 Anbefalinger ---------- */
.quotes{background:var(--bg)}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem)}
.quote{margin:0;border-top:1px solid var(--line);padding-top:2rem}
.quote blockquote{margin:0}
.quote blockquote p{font-family:var(--serif);font-size:clamp(1.25rem,1rem + .9vw,1.6rem);line-height:1.5;font-style:italic;color:#34302a;margin:0 0 1rem}
.quote figcaption{margin-top:1.4rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}

/* ---------- 04 Kontakt ---------- */
.contact{background:var(--bg-2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.contact__intro .display{margin:.2rem 0 1.4rem}
.contact__details{font-style:normal;display:flex;flex-direction:column;gap:.35rem;margin:2rem 0 0;font-size:1rem;color:#3b352e}
.contact__details a:hover{color:var(--accent)}
.contact__social{display:flex;gap:1.5rem;margin-top:1.6rem}
.contact__social a{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);position:relative}
.contact__social a::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.contact__social a:hover::after{transform:scaleX(1)}

.contact__form{display:flex;flex-direction:column;gap:1.2rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);background:transparent;
  border:0;border-bottom:1px solid var(--line);padding:.6rem 0;resize:vertical;
  transition:border-color .3s var(--ease);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.btn{
  align-self:flex-start;cursor:pointer;border:1px solid var(--ink);background:transparent;color:var(--ink);
  font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;padding:.95rem 2.1rem;margin-top:.4rem;
  transition:background .35s var(--ease),color .35s var(--ease);
}
.btn:hover{background:var(--ink);color:var(--bg)}
.contact__note{font-size:.85rem;color:var(--accent);min-height:1.2em;margin:.4rem 0 0;letter-spacing:.02em}

/* ---------- Instagram ---------- */
.instagram{background:var(--bg);padding-bottom:clamp(3rem,6vw,5rem)}
.ig-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem}
.ig-head .overline{margin:0}
.ig-handle{font-family:var(--serif);font-size:clamp(1.4rem,1rem + 1.4vw,2.1rem)}
.ig-handle:hover{color:var(--accent)}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.ig-tile{position:relative;overflow:hidden;background:#ddd6c9}
.ig-tile img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform .9s var(--ease),opacity .4s var(--ease)}
.ig-tile::after{content:"";position:absolute;inset:0;background:rgba(42,37,32,.0);transition:background .4s var(--ease)}
.ig-tile:hover img{transform:scale(1.06)}
.ig-tile:hover::after{background:rgba(42,37,32,.12)}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--line);padding-block:2.4rem}
.footer__grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem 2rem}
.footer__mark{font-size:1rem;letter-spacing:.18em;text-transform:uppercase}
.footer__meta,.footer__copy{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
/* Staggered cascade within the project & instagram grids */
.project-grid .project-card:nth-child(3n+2){transition-delay:.08s}
.project-grid .project-card:nth-child(3n+3){transition-delay:.16s}
.ig-grid .ig-tile:nth-child(2){transition-delay:.05s}
.ig-grid .ig-tile:nth-child(3){transition-delay:.10s}
.ig-grid .ig-tile:nth-child(4){transition-delay:.15s}
.ig-grid .ig-tile:nth-child(5){transition-delay:.20s}
.ig-grid .ig-tile:nth-child(6){transition-delay:.25s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__img,.hero__content{animation:none}
  .hero__cue span{animation:none}
}

/* ---------- Project Modal ---------- */
.modal{position:fixed;inset:0;z-index:100;display:none}
.modal.is-open{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(24,20,16,.62);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade .4s var(--ease) both}
.modal__panel{
  position:absolute;inset:0;margin:auto;width:min(960px,calc(100% - 2rem));max-height:92vh;
  top:4vh;background:var(--bg);overflow-y:auto;overscroll-behavior:contain;
  padding:clamp(1.5rem,4vw,3.5rem);box-shadow:0 30px 80px rgba(0,0,0,.3);
  animation:fadeUp .5s var(--ease) both;
}
.modal__close{position:sticky;top:0;float:right;margin:-.5rem -.5rem 0 0;font-size:2rem;line-height:1;
  background:none;border:0;color:var(--ink);cursor:pointer;width:44px;height:44px;z-index:2}
.modal__head{max-width:48rem}
.modal__head .overline{margin-bottom:.8rem}
.modal__head .display{margin:0 0 1rem}
.modal__deliverables{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin:0 0 1.6rem}
.modal__desc p{margin:0 0 1rem;color:#3b352e;max-width:42rem}
.modal__gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:2.2rem}
.modal__gallery img{width:100%;height:100%;object-fit:cover;background:#ddd6c9}
.modal__gallery img.span{grid-column:1 / -1;aspect-ratio:16/9}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

body.no-scroll{overflow:hidden}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .ig-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .project-grid{grid-template-columns:repeat(2,1fr)}
  .om__grid{grid-template-columns:1fr;gap:2rem}
  .om__media img{aspect-ratio:3/4;max-height:74vh}
  .quote-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact__grid{grid-template-columns:1fr}
  .modal__gallery{grid-template-columns:1fr}
  .modal__gallery img.span{aspect-ratio:4/3}

  /* Mobile nav */
  .nav-toggle{display:block}
  .nav-links{
    /* viewport-relative sizing (vw/dvh) so the overlay stays full-screen even when the
       header's backdrop-filter makes it the containing block for this fixed element */
    position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;
    background:var(--bg);flex-direction:column;align-items:center;justify-content:center;
    gap:2rem;transform:translateY(-100%);transition:transform .45s var(--ease);z-index:58;
  }
  .nav-links.is-open{transform:translateY(0)}
  .nav-links a{color:var(--ink);font-size:1rem}
  .nav-links a.is-active{color:var(--ink)}
  .site-header.menu-open .nav-toggle span{background:var(--ink)}
  .site-header.menu-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .site-header.menu-open .nav-toggle span:nth-child(2){opacity:0}
  .site-header.menu-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}
@media (max-width:520px){
  .project-grid{grid-template-columns:1fr}
  .ig-grid{grid-template-columns:repeat(3,1fr);gap:4px}
  .hero__title{letter-spacing:.3em}
  .om__services{gap:.5rem .45rem}
  .modal__close{position:fixed;top:.5rem;right:.6rem;background:rgba(244,241,234,.85);border-radius:50%}
}
@media (max-width:360px){
  .hero__name{font-size:2.25rem}
  .hero__title{letter-spacing:.22em;font-size:.7rem;padding-left:.22em}
  .hero__tag{font-size:.72rem}
  .om__services li{font-size:.68rem;padding:.45rem .8rem}
}
