/*
Theme Name: RaumAkzente
Theme URI: https://raum-akzente.codlab.de
Author: CodLab — Francesco Cucinotta
Author URI: https://codlab.de
Description: Custom theme für RaumAkzente Regensburg. Brand-Grün (#A0B414) als Leitfarbe, modernes minimalistisches Design, Hero-Video. 1:1 Content vom Original raum-akzente.de.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: Proprietary
Text Domain: raum-akzente
*/

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Geist','Geist Sans',ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:17px;line-height:1.65;color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img,svg,video,picture{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .2s,background-color .2s}
button{font:inherit;cursor:pointer;border:0;background:none}
ul{list-style:none}

/* === Brand palette ===
   Hue 113 = brand yellow-green. Neutrals are subtly tinted toward this hue
   so brand color and surfaces share visual DNA. HEX is the fallback;
   modern browsers get OKLCH via the @supports block below. */
:root{
  --green:#A0B414;
  --green-dark:#7E8F0F;
  --green-light:#B8CC2F;
  --green-tint:#F2F5DA;
  --ink:#1A1F0D;
  --ink-soft:#3A3F2D;
  --paper:#FAFAF6;
  --line:#E8E8E0;
  --muted:#7A7E70;
  --warm:#F5F2E8;
  --shadow:0 4px 24px rgb(26 31 13 / .06);
  --shadow-lg:0 24px 60px -12px rgb(26 31 13 / .14);
  --max:1280px;
  --radius-s:6px;
  --radius:12px;
  --radius-lg:24px;
}
@supports (color: oklch(0 0 0)) {
  :root{
    --green:oklch(0.733 0.166 113);
    --green-dark:oklch(0.585 0.130 113);
    --green-light:oklch(0.802 0.165 113);
    --green-tint:oklch(0.962 0.045 113);
    --ink:oklch(0.190 0.022 113);
    --ink-soft:oklch(0.330 0.026 113);
    --paper:oklch(0.985 0.005 113);
    --line:oklch(0.920 0.011 113);
    --muted:oklch(0.555 0.012 113);
    --warm:oklch(0.965 0.012 92);
    --shadow:0 4px 24px oklch(0.190 0.022 113 / .06);
    --shadow-lg:0 24px 60px -12px oklch(0.190 0.022 113 / .14);
  }
}

/* === Typography === */
h1,h2,h3,h4,h5,h6{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-weight:600;line-height:1.1;letter-spacing:-.015em;color:var(--ink)}
h1{font-size:clamp(2.4rem,6vw,5.2rem);letter-spacing:-.025em;font-weight:500}
h2{font-size:clamp(1.9rem,4vw,3.4rem);font-weight:500}
h3{font-size:clamp(1.3rem,2.2vw,1.8rem);font-weight:600}
h4{font-size:1.2rem;font-weight:600}
.serif{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-weight:400;font-style:italic;letter-spacing:0}
.sans{font-family:'Geist','Geist Sans',ui-sans-serif,sans-serif}
.eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--green-dark);display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:currentColor}
p{margin-bottom:1rem;max-width:65ch;color:var(--ink-soft)}
.lead{font-size:1.2rem;line-height:1.6;color:var(--ink);font-weight:400}
.lead.serif{font-style:italic}
em.hl{font-style:normal;background:linear-gradient(transparent 60%,rgba(160,180,20,.3) 60%);padding:0 .15em}

/* === Layout === */
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.container-narrow{max-width:920px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-lg{padding:7rem 0}
.section-sm{padding:3rem 0}
@media (max-width:700px){.section{padding:4rem 0}.section-lg{padding:5rem 0}}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;gap:.7rem;padding:1rem 1.8rem;font-family:'Geist','Geist Sans',ui-sans-serif,sans-serif;font-size:.92rem;font-weight:600;letter-spacing:.02em;line-height:1;transition:all .25s;cursor:pointer;border:2px solid transparent;border-radius:var(--radius);white-space:nowrap}
.btn-primary{background:var(--green);color:var(--ink)}
.btn-primary:hover{background:var(--green-dark);color:#fff;transform:translateY(-2px);box-shadow:0 12px 24px -8px rgba(160,180,20,.45)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--green);color:var(--ink);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-arrow::after{content:"→";font-size:1.05rem;transition:transform .25s}
.btn-arrow:hover::after{transform:translateX(5px)}

/* === Header === */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(14px) saturate(1.5);-webkit-backdrop-filter:blur(14px) saturate(1.5);border-bottom:1px solid transparent;transition:all .25s}
.site-header.scrolled{background:rgba(255,255,255,.98);border-bottom-color:var(--line);box-shadow:var(--shadow)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;max-width:var(--max);margin:0 auto;gap:2rem}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand-mark{width:2.6rem;height:2.6rem;display:inline-block;flex-shrink:0}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-weight:500;font-size:1.15rem;letter-spacing:-.01em;color:var(--ink)}
.brand-text small{font-family:'Geist','Geist Sans',ui-sans-serif,sans-serif;font-weight:500;font-size:.62rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-top:3px}
.nav-menu{display:flex;gap:1.8rem;align-items:center}
.nav-menu a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;padding:.4rem 0;letter-spacing:-.005em}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--green);transition:width .25s}
.nav-menu a:hover::after,.nav-menu a.current::after{width:100%}
.nav-menu a.nav-cta{padding:.7rem 1.2rem;background:var(--ink);color:#fff;font-size:.82rem;font-weight:600;border-radius:100px;transition:all .2s;letter-spacing:.01em}
.nav-menu a.nav-cta:hover{background:var(--green);color:var(--ink);transform:translateY(-1px)}
.nav-menu a.nav-cta::after{display:none}
.nav-menu a.nav-cta svg{transition:transform .25s}
.nav-menu a.nav-cta:hover svg{transform:rotate(-8deg) scale(1.1)}
.burger{display:none;width:2.4rem;height:2.4rem;flex-direction:column;justify-content:center;gap:5px;align-items:center;cursor:pointer}
.burger span{display:block;width:24px;height:2px;background:var(--ink);transition:all .25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:1024px){
  .nav-menu{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:#fff;flex-direction:column;justify-content:flex-start;padding:6rem 2rem 2rem;gap:1.4rem;transition:right .3s ease;align-items:flex-start;box-shadow:var(--shadow-lg)}
  .nav-menu.open{right:0}
  .nav-menu a{font-size:1.15rem}
  .burger{display:flex}
}

/* === Hero (homepage) === */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;overflow:hidden;color:#fff;isolation:isolate;background:var(--ink)}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.05)}
.hero-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(26,31,13,.65) 0%,rgba(26,31,13,.55) 50%,rgba(26,31,13,.85) 100%)}
.hero-shape{position:absolute;z-index:-1;opacity:.18;pointer-events:none}
.hero-shape.circle-1{top:14%;right:6%;width:240px;height:240px}
.hero-shape.circle-1 svg{width:100%;height:100%}
.hero-content{padding:9rem 0 5rem;width:100%;position:relative}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;padding:.5rem 1rem;background:rgba(160,180,20,.12);border:1px solid rgba(160,180,20,.4);color:var(--green-light);font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.8rem;border-radius:100px}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green-light);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.hero h1{color:#fff;max-width:18ch;margin-bottom:1.6rem;font-weight:400}
.hero h1 .accent{color:var(--green-light);font-style:italic}
.hero-tag{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-style:italic;font-size:1.3rem;color:rgba(255,255,255,.85);max-width:48ch;margin-bottom:2.5rem;font-weight:400;line-height:1.5}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:2.5rem}
/* Hero footer: editorial — single anchor stat + brand pillars (no 3-num SaaS template) */
.hero-foot{display:grid;grid-template-columns:auto 1fr;gap:3rem;padding-top:2.5rem;border-top:1px solid rgb(255 255 255 / .15);max-width:760px;align-items:end}
@media (max-width:700px){.hero-foot{grid-template-columns:1fr;gap:1.5rem}}
.hero-stat-anchor{display:flex;flex-direction:column;line-height:1}
.hero-stat-anchor .num{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(3rem,5vw,4.5rem);line-height:.9;color:var(--green-light);font-weight:300;letter-spacing:-.04em;font-feature-settings:'tnum' 1}
.hero-stat-anchor .num sup{font-size:.5em;font-weight:500;vertical-align:super;color:rgb(255 255 255 / .6);margin-left:.1em}
.hero-stat-anchor .lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgb(255 255 255 / .55);margin-top:.7rem;font-weight:600}
.hero-pillars{display:flex;flex-wrap:wrap;gap:1.4rem;font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:1rem;color:rgb(255 255 255 / .8);align-items:baseline;font-style:italic;font-weight:400}
.hero-pillars span{position:relative;padding-right:1.4rem}
.hero-pillars span:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;width:4px;height:4px;background:var(--green-light);border-radius:50%;transform:translateY(-50%)}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-weight:600}
.hero-scroll-line{width:1px;height:30px;background:rgba(255,255,255,.4)}
@media (max-width:600px){.hero-scroll{display:none}}

/* === Sections === */
.section-head{margin-bottom:3.5rem;display:grid;gap:2rem;grid-template-columns:1fr 1.6fr;align-items:end}
@media (max-width:900px){.section-head{grid-template-columns:1fr}}

/* === Service Bento (asymmetric — 1 hero + 2 stacked, NOT 3-col) === */
.services-bento{display:grid;grid-template-columns:1.3fr 1fr;grid-template-rows:auto auto;gap:1.25rem;align-items:stretch}
@media (max-width:900px){.services-bento{grid-template-columns:1fr}}
.svc-feature{grid-row:span 2;background:var(--ink);color:#fff;padding:3rem 2.5rem;border-radius:var(--radius-lg);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;min-height:32rem;isolation:isolate;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.svc-feature::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 80% 20%, rgb(160 180 20 / .25) 0%, transparent 50%);z-index:-1;opacity:.7;transition:opacity .4s}
.svc-feature:hover{transform:translateY(-2px)}
.svc-feature:hover::before{opacity:1}
.svc-feature .svc-tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green-light);font-weight:600;margin-bottom:auto}
.svc-feature h3{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(2rem,3.5vw,3rem);line-height:1;color:#fff;font-weight:400;letter-spacing:-.02em;margin:1.5rem 0 1rem;max-width:14ch}
.svc-feature h3 em{font-style:italic;color:var(--green-light)}
.svc-feature p{color:rgb(255 255 255 / .75);font-size:.98rem;line-height:1.6;max-width:42ch}
.svc-feature .svc-go{font-size:.82rem;font-weight:600;color:#fff;letter-spacing:.02em;display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 1.4rem;background:rgb(255 255 255 / .08);border:1px solid rgb(255 255 255 / .15);border-radius:100px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:all .25s;align-self:flex-start;margin-top:2rem}
.svc-feature .svc-go:hover{background:var(--green);color:var(--ink);border-color:var(--green);gap:.9rem}

.svc-tile{background:#fff;border:1px solid var(--line);padding:2rem;border-radius:var(--radius);transition:transform .3s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .35s;display:flex;flex-direction:column;gap:.7rem;position:relative;min-height:15.5rem}
.svc-tile:hover{transform:translateY(-2px);border-color:var(--green);box-shadow:var(--shadow-lg)}
.svc-tile .svc-num{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:1rem;color:var(--green-dark);font-weight:600;letter-spacing:-.01em}
.svc-tile h3{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(1.3rem,1.8vw,1.55rem);font-weight:600;letter-spacing:-.01em;line-height:1.15}
.svc-tile p{font-size:.92rem;line-height:1.55;color:var(--ink-soft);max-width:36ch;flex-grow:1;margin-bottom:0}
.svc-tile .svc-go{font-size:.78rem;font-weight:600;color:var(--green-dark);letter-spacing:.04em;display:inline-flex;align-items:center;gap:.4rem;align-self:flex-start;transition:gap .25s,color .25s;border-bottom:1px solid var(--green);padding-bottom:1px}
.svc-tile:hover .svc-go{gap:.7rem;color:var(--ink)}

/* === Process flow (horizontal connected steps — NOT 3 boxed cards) === */
.process-flow{margin-top:3rem;position:relative;padding:2rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.process-flow::before{content:"";position:absolute;left:8%;right:8%;top:50%;height:1px;background:repeating-linear-gradient(to right,var(--line) 0 8px,transparent 8px 16px);transform:translateY(-50%);z-index:0}
@media (max-width:700px){.process-flow::before{display:none}}
.process-track{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;position:relative;z-index:1}
@media (max-width:700px){.process-track{grid-template-columns:1fr;gap:2rem}}
.process-node{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;padding:1.5rem 1.5rem;background:var(--paper);border-radius:var(--radius);position:relative}
.process-node:nth-child(2){transform:translateY(.8rem)}
.process-node:nth-child(3){transform:translateY(1.6rem)}
@media (max-width:700px){.process-node,.process-node:nth-child(2),.process-node:nth-child(3){transform:none}}
.process-node .num{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:.78rem;letter-spacing:.18em;color:var(--green-dark);font-weight:700;text-transform:uppercase;display:flex;align-items:center;gap:.6rem}
.process-node .num::before{content:"";width:.55rem;height:.55rem;background:var(--green);border-radius:50%;box-shadow:0 0 0 4px var(--green-tint)}
.process-node h4{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:1.4rem;font-weight:500;letter-spacing:-.01em;line-height:1.1}
.process-node p{font-size:.92rem;color:var(--ink-soft);margin:0;max-width:34ch;line-height:1.55}

/* === Owner / About callout === */
.owner-feature{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;padding:5rem 0}
@media (max-width:1000px){.owner-feature{grid-template-columns:1fr;gap:3rem}}
.owner-img{position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-lg)}
.owner-img::before{content:"";position:absolute;top:1.5rem;left:1.5rem;right:-1.5rem;bottom:-1.5rem;background:var(--green);border-radius:var(--radius-lg);z-index:-1}
.owner-img img{width:100%;height:100%;object-fit:cover}

/* === Stats === */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:3rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:3rem 0}
@media (max-width:700px){.stats-row{grid-template-columns:repeat(2,1fr);gap:2rem}}
.stat{text-align:left}
.stat-num{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-size:2.6rem;line-height:1;color:var(--green-dark);font-weight:500;display:block;letter-spacing:-.02em}
.stat-num .plus{color:var(--green)}
.stat-label{font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;font-weight:600}

/* === Testimonial (asymmetric, off-center, NOT center-quote pattern) === */
.testimonial{padding:6rem 0;background:var(--green-tint);position:relative;overflow:hidden}
.testimonial-grid{display:grid;grid-template-columns:1fr 2.4fr;gap:4rem;align-items:start;max-width:var(--max);margin:0 auto;padding:0 1.5rem}
@media (max-width:900px){.testimonial-grid{grid-template-columns:1fr;gap:1.5rem}}
.testimonial-meta{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}
.testimonial-meta .stars{display:flex;gap:.2rem;color:var(--green-dark)}
.testimonial-meta .stars svg{width:1.1rem;height:1.1rem}
.testimonial-meta .src{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-dark);font-weight:700}
.testimonial-meta cite{font-style:normal;font-size:1rem;font-weight:600;color:var(--ink);font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;line-height:1.3;display:block}
.testimonial-meta cite small{display:block;font-weight:400;color:var(--ink-soft);margin-top:.2rem;font-size:.85rem}
.testimonial blockquote{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.25;color:var(--ink);font-style:italic;font-weight:400;letter-spacing:-.01em;position:relative;margin:0;max-width:none;text-align:left}
.testimonial blockquote::before{content:"\201C";font-size:5em;line-height:.4;color:var(--green-dark);position:absolute;left:-.5em;top:.45em;opacity:.4;font-weight:600;font-style:normal}
@media (max-width:600px){.testimonial blockquote::before{display:none}}
.testimonial blockquote strong{font-style:normal;background:var(--green);color:var(--ink);padding:0 .15em;font-weight:600}

/* === Projects asymmetric Bento (1 large feature + 2 stacked) === */
.projects-bento{display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:auto auto;gap:1.25rem}
@media (max-width:900px){.projects-bento{grid-template-columns:1fr}}
.proj-feature{grid-row:span 2;display:block;position:relative;overflow:hidden;border-radius:var(--radius-lg);aspect-ratio:auto;min-height:32rem;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.proj-feature:hover{transform:translateY(-2px)}
.proj-feature picture,.proj-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.proj-feature:hover picture img,.proj-feature:hover img{transform:scale(1.05)}
.proj-feature::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgb(26 31 13 / .85) 0%,rgb(26 31 13 / .35) 35%,transparent 60%);transition:opacity .35s}
.proj-feature .body{position:absolute;left:2rem;right:2rem;bottom:2rem;color:#fff;z-index:2}
.proj-feature .cat{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green-light);font-weight:700;display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.proj-feature .cat::before{content:"";width:1.6rem;height:1px;background:var(--green-light)}
.proj-feature h3{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(1.6rem,2.4vw,2rem);font-weight:500;letter-spacing:-.01em;color:#fff;margin-bottom:.7rem;line-height:1.1;max-width:18ch}
.proj-feature p{color:rgb(255 255 255 / .82);font-size:.95rem;line-height:1.5;max-width:42ch;margin-bottom:0}

.proj-tile{display:block;position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/3;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.proj-tile:hover{transform:translateY(-2px)}
.proj-tile picture,.proj-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.proj-tile:hover picture img,.proj-tile:hover img{transform:scale(1.05)}
.proj-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgb(26 31 13 / .82) 0%,rgb(26 31 13 / .25) 50%,transparent 75%)}
.proj-tile .body{position:absolute;left:1.4rem;right:1.4rem;bottom:1.4rem;color:#fff;z-index:2}
.proj-tile .cat{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-light);font-weight:700;margin-bottom:.4rem}
.proj-tile h3{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:1.15rem;font-weight:500;color:#fff;letter-spacing:-.01em;line-height:1.15;margin-bottom:0;max-width:22ch}

/* === Project detail (full gallery) === */
.project-detail{margin:5rem 0}
.project-hero-img{aspect-ratio:21/9;overflow:hidden;border-radius:var(--radius);margin-bottom:2.5rem}
.project-hero-img img{width:100%;height:100%;object-fit:cover}
.project-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
@media (max-width:700px){.project-gallery{grid-template-columns:repeat(2,1fr)}}
.project-gallery figure{aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-s);background:var(--paper);position:relative}
.project-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.project-gallery figure:hover img{transform:scale(1.04)}

/* === CTA banner === */
.cta-banner{background:var(--ink);color:#fff;padding:5rem 0;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;top:-30%;right:-12%;width:50%;aspect-ratio:1;background:var(--green);border-radius:50%;opacity:.12}
.cta-banner h2{color:#fff;margin-bottom:1rem;font-weight:400}
.cta-banner p{color:rgba(255,255,255,.78);font-size:1.1rem;max-width:48ch;margin-bottom:2rem}

.cta-banner-green{background:var(--green);color:var(--ink)}
.cta-banner-green::before{background:var(--ink);opacity:.08}
.cta-banner-green h2,.cta-banner-green p{color:var(--ink)}
.cta-banner-green p{color:var(--ink-soft)}

/* === Footer === */
.site-footer{background:var(--ink);color:#fff;padding:5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr;gap:2.5rem}}
.footer-brand p{color:rgba(255,255,255,.7);font-size:.95rem;line-height:1.6;max-width:38ch}
.footer-brand .brand{color:#fff;margin-bottom:1.5rem}
.footer-brand .brand-text strong{color:#fff}
.footer-brand .brand-text small{color:rgba(255,255,255,.5)}
.footer-col h5{font-family:'Geist','Geist Sans',ui-sans-serif,sans-serif;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-light);margin-bottom:1.4rem;font-weight:700}
.footer-col ul li{margin-bottom:.7rem}
.footer-col a{color:rgba(255,255,255,.78);font-size:.95rem}
.footer-col a:hover{color:var(--green-light)}
.footer-col address{font-style:normal;color:rgba(255,255,255,.78);font-size:.95rem;line-height:1.7}
.footer-col address strong{color:#fff;display:block;margin-bottom:.5rem}
.footer-bottom{padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:rgba(255,255,255,.5)}
.footer-bottom .legal{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:#fff}

/* === Page hero (interior pages) === */
.page-hero{padding:9rem 0 4.5rem;background:var(--paper);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero::after{content:"";position:absolute;right:-8%;top:30%;width:24rem;height:24rem;border:24px solid var(--green);border-radius:50%;opacity:.1;z-index:0}
.page-hero .container{position:relative;z-index:1}
.page-hero .breadcrumb{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;font-weight:500}
.page-hero .breadcrumb a{color:var(--ink-soft);font-weight:600}
.page-hero .breadcrumb a:hover{color:var(--green-dark)}
.page-hero .breadcrumb span.sep{margin:0 .5rem;color:var(--line)}
.page-hero h1{margin-bottom:1.5rem}
.page-hero .lead{max-width:62ch;color:var(--ink-soft)}

/* === Service detail rows === */
.service-detail{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:center;padding:5rem 0;border-bottom:1px solid var(--line)}
.service-detail:nth-child(even){grid-template-columns:1.2fr 1fr}
.service-detail:nth-child(even) .sd-text{order:2}
.service-detail:nth-child(even) .sd-img{order:1}
@media (max-width:900px){.service-detail,.service-detail:nth-child(even){grid-template-columns:1fr;gap:2rem}.service-detail:nth-child(even) .sd-text{order:1}.service-detail:nth-child(even) .sd-img{order:0}}
.sd-num{font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif;font-size:.9rem;font-weight:500;color:var(--green-dark);margin-bottom:1rem;display:flex;align-items:center;gap:.7rem;letter-spacing:.05em}
.sd-num::before{content:"";width:1.6rem;height:2px;background:var(--green)}
.sd-text h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:1.5rem;font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif}
.sd-text p{color:var(--ink-soft);font-size:1rem;line-height:1.7}
.sd-img{aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius);position:relative}
.sd-img img{width:100%;height:100%;object-fit:cover}
.sd-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;list-style:none}
.sd-tags li{font-size:.78rem;letter-spacing:.04em;background:var(--green-tint);padding:.4rem .9rem;border-radius:100px;font-weight:500;color:var(--green-dark)}

/* === Values (editorial big-number style — intentionally NOT another card grid) === */
.values-grid{display:grid;grid-template-columns:1fr;gap:0;margin-top:3rem;border-top:1px solid var(--line)}
.value{display:grid;grid-template-columns:auto 1fr 2fr;gap:3rem;padding:2.5rem 0;border-bottom:1px solid var(--line);align-items:start;transition:background .25s}
.value:hover{background:var(--green-tint)}
@media (max-width:800px){.value{grid-template-columns:1fr;gap:.8rem}}
.value-num{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(2rem,4vw,3.4rem);line-height:1;color:var(--green-dark);font-weight:300;letter-spacing:-.02em;font-feature-settings:'tnum' 1;font-variant-numeric:tabular-nums}
.value-title{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(1.2rem,2vw,1.6rem);font-weight:600;line-height:1.2;color:var(--ink);letter-spacing:-.01em;padding-top:.4rem}
.value-body{font-size:1rem;color:var(--ink-soft);max-width:55ch;padding-top:.6rem;line-height:1.6}
.value-icon{display:none}

/* === Contact === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}
.contact-info dt{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-top:2rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.6rem}
.contact-info dt:first-child{margin-top:0}
.contact-info dt svg{width:1.1rem;height:1.1rem;color:var(--green)}
.contact-info dd{font-size:1.1rem;color:var(--ink);margin-bottom:1.4rem}
.contact-info dd a{color:var(--ink);border-bottom:2px solid var(--green);transition:all .2s;padding-bottom:1px}
.contact-info dd a:hover{background:var(--green-tint);border-bottom-color:var(--green-dark)}
.contact-form{background:var(--paper);padding:2.5rem;border:1px solid var(--line);border-radius:var(--radius)}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
@media (max-width:600px){.contact-form .row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.2rem}
.field label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.field input,.field textarea,.field select{padding:.85rem 1rem;border:1px solid var(--line);background:#fff;font-family:inherit;font-size:1rem;color:var(--ink);outline:none;transition:border-color .2s;border-radius:var(--radius-s)}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--green)}

/* === WhatsApp button === */
.wa-btn{display:inline-flex;align-items:center;gap:.7rem;padding:.95rem 1.6rem;background:#25D366;color:#fff;font-weight:600;font-size:.9rem;border-radius:var(--radius);transition:all .2s}
.wa-btn:hover{background:#1DA851;transform:translateY(-2px);color:#fff}
.wa-btn svg{width:1.2rem;height:1.2rem}

/* === Picture wrappers === */
picture{display:block}
picture img{width:100%;height:auto}
.project-img picture,.sd-img picture,.owner-img picture{width:100%;height:100%}
.project-img picture img,.sd-img picture img,.owner-img picture img{width:100%;height:100%;object-fit:cover}
.project-gallery figure picture{width:100%;height:100%}
.project-gallery figure picture img{width:100%;height:100%;object-fit:cover}

/* === Utility === */
.text-center{text-align:center}
.bg-paper{background:var(--paper)}
.bg-tint{background:var(--green-tint)}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink h2,.bg-ink h3,.bg-ink h4{color:#fff}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* === Legal text === */
.legal-text h2{font-size:1.6rem;margin-bottom:1rem;font-family:'Schibsted Grotesk',ui-sans-serif,system-ui,sans-serif}
.legal-text h3{font-size:1.1rem;margin-top:2.5rem;margin-bottom:.7rem;color:var(--ink);font-family:'Geist','Geist Sans',ui-sans-serif,sans-serif;font-weight:700}
.legal-text p,.legal-text ul,.legal-text dl{font-size:.98rem;color:var(--ink-soft);line-height:1.7;margin-bottom:1rem}
.legal-text dl dt{font-weight:600;color:var(--ink);margin-top:.5rem}
.legal-text dl dd{margin-bottom:1rem;margin-left:0}
.legal-text a{color:var(--green-dark);border-bottom:1px solid var(--green);transition:background .2s}
.legal-text a:hover{background:var(--green-tint)}

/* === Print === */
@media print{
  .site-header,.site-footer,.cta-banner,video,.hero-shape{display:none!important}
  .hero{min-height:auto;color:var(--ink);background:#fff}
  .hero h1{color:var(--ink)}
}

/* === Kinetic marquee divider (anti-AI: kinetic typography) === */
.kinetic-marquee{padding:3rem 0;background:var(--ink);color:#fff;overflow:hidden;border-top:1px solid rgb(255 255 255 / .08);border-bottom:1px solid rgb(255 255 255 / .08)}
.marquee-track{display:flex;gap:3rem;width:max-content;animation:scroll-x 40s linear infinite;will-change:transform;font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:clamp(2rem,6vw,5rem);font-weight:300;letter-spacing:-.03em;line-height:1;white-space:nowrap;align-items:center}
.marquee-track:hover{animation-play-state:paused}
.marquee-track span{display:inline-flex;align-items:center;gap:3rem}
.marquee-track .sep{display:inline-block;width:.7em;height:.7em;background:var(--green);border-radius:50%;flex-shrink:0}
.marquee-track em{color:var(--green);font-style:italic;font-weight:400}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* === Scroll progress bar === */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--green);z-index:200;transition:width .12s linear;will-change:width}

/* === Section meta-num corner (editorial) === */
.section-meta-num{position:absolute;top:2rem;right:2rem;font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:5rem;line-height:.8;color:var(--line);font-weight:200;letter-spacing:-.04em;pointer-events:none;z-index:0;font-feature-settings:'tnum' 1}
@media (max-width:700px){.section-meta-num{font-size:3rem;top:1rem;right:1rem}}

/* === Tactile feedback on buttons === */
.btn:active,.svc-go:active,.proj-feature:active,.proj-tile:active,.svc-tile:active{transform:translateY(1px) scale(.99)}

/* === Better focus states (a11y) === */
:where(a,button,input,textarea,select):focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:2px}
.btn:focus-visible{outline-offset:5px}

/* === Anti-Inter / cleanup typography for body === */
.brand-text strong{font-feature-settings:'ss01' 1,'ss02' 1}
.eyebrow{font-feature-settings:'tnum' 1}

/* === Magnetic-feel CTA (CSS only, no JS) === */
.btn-primary{position:relative;isolation:isolate;overflow:hidden}
.btn-primary::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgb(255 255 255 / .35) 0%,transparent 60%);opacity:0;transition:opacity .25s;z-index:-1;pointer-events:none}
.btn-primary:hover::before{opacity:1}

/* === CodLab signature badge (footer) === */
.footer-codlab{display:flex;justify-content:center;margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgb(255 255 255 / .06)}
.codlab-glass-badge{display:inline-flex;align-items:center;gap:.7rem;padding:.6rem 1.2rem;border-radius:100px;background:rgb(255 255 255 / .04);border:1px solid rgb(255 255 255 / .07);text-decoration:none;transition:all .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.codlab-glass-badge:hover{background:rgb(255 255 255 / .08);border-color:rgb(160 180 20 / .35);transform:translateY(-1px);box-shadow:0 6px 24px -8px rgb(160 180 20 / .25)}
.codlab-text{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgb(255 255 255 / .42);font-family:'Geist','Inter',system-ui,sans-serif;font-weight:600;transition:color .3s}
.codlab-glass-badge:hover .codlab-text{color:rgb(255 255 255 / .8)}
.codlab-logo{height:14px;width:auto;opacity:.55;transition:opacity .3s}
.codlab-glass-badge:hover .codlab-logo{opacity:1}

/* === Cookie consent banner === */
.cookie-banner{position:fixed;bottom:1.5rem;left:1.5rem;right:1.5rem;max-width:540px;margin-left:auto;background:#fff;color:var(--ink);padding:1.6rem 1.8rem;border-radius:var(--radius-lg);box-shadow:0 24px 60px -12px rgb(26 31 13 / .3),0 0 0 1px rgb(26 31 13 / .04);z-index:300;transform:translateY(120%);opacity:0;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .3s;will-change:transform}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner[hidden]{display:none}
@media (max-width:600px){.cookie-banner{bottom:1rem;left:1rem;right:1rem;padding:1.3rem 1.4rem}}
.cookie-head{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}
.cookie-head .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 0 4px var(--green-tint)}
.cookie-head h3{font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:1rem;font-weight:600;letter-spacing:-.005em;margin:0;line-height:1}
.cookie-banner p{font-size:.88rem;line-height:1.55;color:var(--ink-soft);margin:0 0 1.2rem;max-width:none}
.cookie-banner p a{color:var(--ink);font-weight:600;border-bottom:1px solid var(--green);transition:background .2s}
.cookie-banner p a:hover{background:var(--green-tint)}
.cookie-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.cookie-btn{font-family:'Geist','Inter',sans-serif;font-size:.82rem;font-weight:600;padding:.7rem 1.2rem;border-radius:100px;cursor:pointer;border:1px solid var(--ink);transition:all .2s;letter-spacing:.01em}
.cookie-btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.cookie-btn-primary:hover{background:var(--green);color:var(--ink);border-color:var(--green);transform:translateY(-1px)}
.cookie-btn-ghost{background:transparent;color:var(--ink);border-color:rgb(26 31 13 / .2)}
.cookie-btn-ghost:hover{border-color:var(--ink);background:var(--paper)}
.cookie-btn-link{background:none;border:none;color:var(--muted);font-size:.78rem;text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px;padding:.7rem 0;cursor:pointer;transition:color .2s}
.cookie-btn-link:hover{color:var(--ink);text-decoration-color:var(--green)}

/* Settings panel (revealed) */
.cookie-settings{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line);display:none}
.cookie-settings.is-open{display:block}
.cookie-row{display:flex;justify-content:space-between;align-items:start;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.cookie-row:last-child{border-bottom:0}
.cookie-row-info strong{display:block;font-family:'Schibsted Grotesk',ui-sans-serif,sans-serif;font-size:.88rem;font-weight:600;color:var(--ink);margin-bottom:.2rem}
.cookie-row-info small{font-size:.78rem;color:var(--muted);line-height:1.45;display:block;max-width:34ch}
.cookie-toggle{appearance:none;-webkit-appearance:none;width:2.6rem;height:1.4rem;background:var(--line);border-radius:100px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;margin-top:.2rem}
.cookie-toggle::after{content:"";position:absolute;left:.15rem;top:.15rem;width:1.1rem;height:1.1rem;background:#fff;border-radius:50%;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 3px rgb(0 0 0 / .15)}
.cookie-toggle:checked{background:var(--green)}
.cookie-toggle:checked::after{transform:translateX(1.2rem)}
.cookie-toggle:disabled{background:var(--green);opacity:.6;cursor:not-allowed}
