  :root{
    --paper:#f3efe8;
    --paper-2:#ece5da;
    --sand:#e4dccd;
    --ink:#221f1b;
    --ink-2:#3a352e;
    --ink-soft:#6c655a;
    --line:#d9d2c5;
    --line-2:#c5bcab;
    --accent:#bd6a4b;        /* terracotta */
    --accent-deep:#9c5236;
    --accent-soft:#d99a80;
    --disp:'Schibsted Grotesk', system-ui, sans-serif;
    --mono:'Spline Sans Mono', monospace;
    --ease:cubic-bezier(.22,.61,.36,1);
  }
  *{box-sizing:border-box;margin:0;padding:0;}
  html{scroll-behavior:smooth;}
  body{
    font-family:var(--disp);
    background:var(--paper);
    color:var(--ink);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  ::selection{background:var(--accent);color:#fff;}
  a{color:inherit;text-decoration:none;}
  img{display:block;max-width:100%;}

  /* paper grain */
  body::before{
    content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
  }

  .wrap{max-width:1180px;margin:0 auto;padding:0 40px;}
  .kicker{font-family:var(--mono);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-deep);}
  .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);}
  .muted{color:var(--ink-soft);}

  /* ============ HEADER ============ */
  header{
    position:fixed;top:0;left:0;right:0;z-index:40;
    transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
    padding:22px 0;
  }
  header.solid{background:rgba(243,239,232,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding:14px 0;}
  .hd{display:flex;align-items:center;gap:32px;}
  .nav{display:flex;gap:30px;margin-left:auto;}
  .nav a{font-size:14.5px;font-weight:500;color:var(--ink-2);position:relative;padding:4px 0;transition:color .2s;}
  .nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--accent);transition:width .28s var(--ease);}
  .nav a:hover{color:var(--ink);}
  .nav a:hover::after{width:100%;}
  .hd-right{display:flex;align-items:center;gap:18px;}
  .langtog{display:flex;border:1px solid var(--line-2);border-radius:30px;overflow:hidden;font-family:var(--mono);font-size:11px;}
  .langtog button{appearance:none;border:0;background:transparent;padding:6px 11px;cursor:pointer;color:var(--ink-soft);font-family:var(--mono);transition:.2s;}
  .langtog button.on{background:var(--ink);color:var(--paper);}
  .btn{
    display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:600;font-size:14.5px;cursor:pointer;
    padding:11px 22px;border-radius:30px;border:1.5px solid var(--ink);background:transparent;color:var(--ink);
    transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;
  }
  .btn:hover{transform:translateY(-2px);}
  .btn.solid{background:var(--accent);border-color:var(--accent);color:#fff;}
  .btn.solid:hover{background:var(--accent-deep);border-color:var(--accent-deep);}
  .btn .arr{transition:transform .25s var(--ease);}
  .btn:hover .arr{transform:translateX(4px);}

  /* ============ LOGO ============ */
  .logo{display:flex;align-items:center;gap:11px;}
  .logo .mk{display:flex;align-items:center;gap:2.5px;height:26px;}
  .logo .mk i{width:3px;border-radius:3px;background:var(--accent);display:block;transition:height .3s var(--ease);}
  .logo:hover .mk i{background:var(--accent-deep);}
  .logo .wm{font-weight:800;font-size:17px;letter-spacing:.005em;line-height:.95;}
  .logo .wm small{display:block;font-family:var(--mono);font-weight:500;font-size:8px;letter-spacing:.32em;color:var(--ink-soft);margin-top:4px;}

  /* ============ HERO ============ */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:90px;overflow:hidden;}
  #wave-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
  .hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:0;width:100%;}
  .hero h1{
    font-size:clamp(44px,7.2vw,104px);font-weight:800;line-height:.98;letter-spacing:-.025em;
    max-width:15ch;
  }
  .hero h1 em{font-style:normal;color:var(--accent-deep);}
  .hero .sub{font-size:clamp(16px,1.5vw,20px);line-height:1.55;color:var(--ink-soft);max-width:46ch;margin-top:28px;}
  .hero .cta{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap;}
  .hero .meta{position:absolute;bottom:34px;left:0;right:0;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;}
  .hero .meta .axis{display:flex;justify-content:space-between;width:100%;}
  .scrollcue{display:flex;align-items:center;gap:10px;}
  .scrollcue .ln{width:46px;height:1.5px;background:var(--line-2);position:relative;overflow:hidden;}
  .scrollcue .ln::after{content:"";position:absolute;left:-40%;top:0;height:100%;width:40%;background:var(--accent);animation:slide 2.2s var(--ease) infinite;}
  @keyframes slide{0%{left:-40%;}100%{left:100%;}}

  /* reveal */
  .rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
  .rv.in{opacity:1;transform:none;}
  .rv.d1{transition-delay:.08s;}.rv.d2{transition-delay:.16s;}.rv.d3{transition-delay:.24s;}.rv.d4{transition-delay:.32s;}

  /* ============ SECTIONS ============ */
  section{position:relative;z-index:2;}
  .pad{padding:120px 0;}
  .pad-s{padding:90px 0;}
  .rule{height:1px;background:var(--line);}

  /* manifesto */
  .manifesto{font-size:clamp(26px,3.4vw,46px);font-weight:600;line-height:1.28;letter-spacing:-.015em;max-width:24ch;}
  .manifesto em{font-style:normal;color:var(--accent-deep);}

  /* offer */
  .sechead{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:54px;flex-wrap:wrap;}
  .sechead h2{font-size:clamp(28px,3.6vw,44px);font-weight:800;letter-spacing:-.02em;line-height:1;}
  .offer{display:grid;grid-template-columns:1fr 1fr;gap:30px;}
  .tile .ph{position:relative;height:340px;border-radius:10px;overflow:hidden;background:var(--sand);}
  .ph{
    position:relative;
    background-image:repeating-linear-gradient(135deg,transparent 0 13px,rgba(157,148,131,.16) 13px 14px);
    display:flex;align-items:flex-end;justify-content:flex-start;
  }
  .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;}
  .ph .tag{position:relative;z-index:2;font-family:var(--mono);font-size:11px;color:var(--ink-2);background:rgba(243,239,232,.92);padding:5px 10px;border-radius:5px;margin:14px;letter-spacing:.05em;}
  .tile h3{font-size:23px;font-weight:700;margin:22px 0 10px;letter-spacing:-.01em;}
  .tile p{color:var(--ink-soft);font-size:15.5px;line-height:1.6;max-width:42ch;}

  /* stats */
  .stats{background:var(--ink);color:var(--paper);border-radius:18px;padding:72px 60px;position:relative;overflow:hidden;}
  .stats::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;border:1px solid rgba(255,255,255,.07);}
  .stats .row{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative;z-index:2;}
  .stat .n{font-size:clamp(54px,7vw,88px);font-weight:800;line-height:.9;letter-spacing:-.03em;}
  .stat .n b{color:var(--accent-soft);font-weight:800;}
  .stat .c{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#a59c8e;margin-top:16px;}
  .stats .intro{max-width:46ch;margin-bottom:46px;position:relative;z-index:2;}
  .stats .intro h2{font-size:clamp(26px,3vw,38px);font-weight:700;letter-spacing:-.02em;line-height:1.1;color:#fff;}
  .stats .intro p{color:#b4ab9c;margin-top:16px;font-size:16px;line-height:1.55;}

  /* products */
  .prod{border-top:1px solid var(--line);}
  .prow{
    display:grid;grid-template-columns:54px 1.1fr 1.6fr 44px;align-items:center;gap:20px;
    padding:30px 8px;border-bottom:1px solid var(--line);cursor:default;position:relative;transition:padding .3s var(--ease);
  }
  .prow::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);opacity:.06;transition:width .35s var(--ease);z-index:-1;}
  .prow:hover::before{width:100%;}
  .prow:hover{padding-left:22px;}
  .prow .idx{font-family:var(--mono);font-size:13px;color:var(--accent-deep);}
  .prow .nm{font-size:clamp(20px,2.4vw,30px);font-weight:700;letter-spacing:-.015em;}
  .prow .ds{color:var(--ink-soft);font-size:15px;line-height:1.5;}
  .prow .go{justify-self:end;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:.3s var(--ease);}
  .prow:hover .go{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg);}

  /* spaces */
  .spaces{display:flex;flex-wrap:wrap;gap:12px;}
  .spaces .sp{font-family:var(--mono);font-size:13px;letter-spacing:.02em;padding:11px 18px;border:1px solid var(--line-2);border-radius:30px;color:var(--ink-2);transition:.25s var(--ease);}
  .spaces .sp:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-2px);}

  /* projects */
  .pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
  .pj{position:relative;border-radius:10px;overflow:hidden;background:var(--sand);height:300px;cursor:pointer;}
  .pj .ph{position:absolute;inset:0;}
  .pj .cap{position:absolute;left:0;right:0;bottom:0;top:auto;z-index:2;padding:60px 18px 16px;color:#fff;opacity:1;transition:.35s var(--ease);background:linear-gradient(rgba(20,17,13,0),rgba(20,17,13,.92));}
  .pj .cap::before{content:"";position:absolute;left:0;right:0;bottom:0;top:-60px;background:linear-gradient(rgba(20,17,13,0),rgba(20,17,13,.55));pointer-events:none;z-index:-1;}
  .pj:hover .cap{background:linear-gradient(rgba(34,31,27,0),rgba(20,17,13,.98));}
  .pj .cap .t{font-size:17px;font-weight:700;letter-spacing:-.005em;text-shadow:0 1px 4px rgba(0,0,0,.55);position:relative;}
  .pj .cap .m{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:#e8dccb;margin-top:4px;text-shadow:0 1px 3px rgba(0,0,0,.55);position:relative;}
  .pj:hover{box-shadow:0 18px 40px -20px rgba(34,31,27,.5);}

  /* CTA */
  .cta-band{text-align:center;padding:130px 0;}
  .cta-band h2{font-size:clamp(36px,6vw,78px);font-weight:800;letter-spacing:-.03em;line-height:.98;max-width:16ch;margin:0 auto 16px;}
  .cta-band p{color:var(--ink-soft);font-size:18px;margin-bottom:38px;}
  .cta-band .mini-wave{display:flex;align-items:center;justify-content:center;gap:4px;height:40px;margin-bottom:34px;}
  .cta-band .mini-wave i{width:4px;border-radius:3px;background:var(--accent);animation:mw 1.8s var(--ease) infinite;}
  @keyframes mw{0%,100%{height:8px;}50%{height:34px;}}

  /* footer */
  footer{background:var(--ink);color:var(--paper);padding:80px 0 40px;}
  footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;}
  footer .wm-f{font-weight:800;font-size:22px;letter-spacing:.01em;}
  footer .mk-f{display:flex;align-items:center;gap:2.5px;height:24px;margin-bottom:16px;}
  footer .mk-f i{width:3px;border-radius:3px;background:var(--accent-soft);display:block;}
  footer p,footer a{color:#b4ab9c;font-size:14px;line-height:2;}
  footer a:hover{color:#fff;}
  footer .fl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#7d756a;margin-bottom:14px;}
  footer .bottom{display:flex;justify-content:space-between;align-items:center;margin-top:64px;padding-top:26px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;gap:14px;}
  footer .bottom span{font-family:var(--mono);font-size:11px;color:#7d756a;letter-spacing:.05em;}

  @media(max-width:900px){
    footer .top{grid-template-columns:1fr 1fr;}
    .pgrid{grid-template-columns:1fr 1fr;}
  }
  @media(max-width:720px){
    .wrap{padding:0 22px;}
    .nav{display:none;}
    .offer{grid-template-columns:1fr;}
    .pgrid{grid-template-columns:1fr;}
    .prow{grid-template-columns:30px 1fr;gap:10px;}
    .prow .ds,.prow .go{display:none;}
    .stats{padding:44px 26px;}
    .stats .row{grid-template-columns:1fr;gap:34px;}
    .pad{padding:80px 0;}
    .hero .meta{position:static;margin-top:40px;}
    footer .top{grid-template-columns:1fr;}
  }
  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}.rv{opacity:1;transform:none;}}

  /* ============ LIGHTBOX ============ */
  #lightbox{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;}
  #lightbox.open{display:flex;}
  .lb-backdrop{position:absolute;inset:0;background:rgba(20,17,13,.92);backdrop-filter:blur(6px);z-index:1;cursor:zoom-out;}
  .lb-stage{position:relative;z-index:2;max-width:min(1400px,92vw);max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:18px;pointer-events:none;}
  .lb-img{max-width:100%;max-height:78vh;border-radius:8px;box-shadow:0 30px 80px -30px rgba(0,0,0,.7);pointer-events:auto;animation:lbIn .35s var(--ease);}
  @keyframes lbIn{from{opacity:0;transform:scale(.97);}to{opacity:1;transform:none;}}
  .lb-info{color:var(--paper);text-align:center;pointer-events:auto;}
  .lb-info .lb-cat{color:var(--accent-soft);margin-bottom:6px;}
  .lb-info .lb-title{font-size:clamp(18px,2vw,24px);font-weight:700;letter-spacing:-.01em;}
  .lb-info .lb-count{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:#a59c8e;margin-top:6px;text-transform:uppercase;}
  .lb-close,.lb-prev,.lb-next{position:absolute;z-index:3;appearance:none;border:1.5px solid rgba(255,255,255,.25);background:rgba(20,17,13,.4);color:#fff;cursor:pointer;font-family:var(--disp);transition:.25s var(--ease);backdrop-filter:blur(6px);}
  .lb-close{top:22px;right:22px;width:48px;height:48px;border-radius:50%;font-size:28px;line-height:1;display:flex;align-items:center;justify-content:center;}
  .lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;font-size:32px;line-height:1;display:flex;align-items:center;justify-content:center;}
  .lb-prev{left:22px;} .lb-next{right:22px;}
  .lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-50%) scale(1.05);}
  .lb-close:hover{transform:scale(1.05);}
  .pj{cursor:zoom-in;}
  @media(max-width:720px){
    .lb-prev,.lb-next{width:42px;height:42px;font-size:24px;}
    .lb-prev{left:10px;} .lb-next{right:10px;}
    .lb-close{top:12px;right:12px;width:40px;height:40px;font-size:22px;}
  }
