/* ═══════════════════════════════════════════
   martynkova.cz — Global Stylesheet
   ═══════════════════════════════════════════ */

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ─── THEME TOKENS ─── */
:root{
  --accent:#B5634A;
  --accent-hover:#9A5340;
  --fd:'DM Serif Display',Georgia,serif;
  --fb:'Inter',system-ui,sans-serif;
  --page-px:20px;
  --site-max:1440px;
  --content-max:800px;

  /* Dark theme (default) */
  --bg:#1C1915;
  --bg2:#252119;
  --fg:#D5CBBA;
  --fg-muted:rgba(213,203,186,.65);
  --fg-subtle:rgba(213,203,186,.48);
  --fg-faint:rgba(213,203,186,.26);
  --border:rgba(213,203,186,.08);
  --border-mid:rgba(213,203,186,.14);
  --border-strong:rgba(213,203,186,.32);
  --surface:rgba(213,203,186,.05);
  --surface-hover:rgba(213,203,186,.10);
  --nav-bg:rgba(28,25,21,.8);
  --nav-border:rgba(213,203,186,.08);

  --bg-inv:#F0EEE9;
  --bg-inv2:#E5DFD5;
  --fg-inv:#2A2420;
  --fg-inv-muted:rgba(42,36,32,.75);
  --fg-inv-subtle:rgba(42,36,32,.58);
  --fg-inv-faint:rgba(42,36,32,.38);
  --border-inv:rgba(42,36,32,.10);
  --border-inv-mid:rgba(42,36,32,.18);
  --surface-inv:rgba(42,36,32,.05);
  --surface-inv-hover:rgba(42,36,32,.09);

  --scrollbar-bg:var(--bg);
  --scrollbar-thumb:rgba(213,203,186,.12);
}

@media(min-width:768px){:root{--page-px:32px}}
@media(min-width:1024px){:root{--page-px:44px}}

/* ─── LAYOUT HELPERS ─── */
/* Full-bleed section with centered content */
.wrap{
  max-width:var(--site-max);
  margin:0 auto;
  padding-left:var(--page-px);
  padding-right:var(--page-px);
}
/* Narrow text column */
.wrap--narrow{max-width:var(--content-max)}

/* ─── BASE ─── */
html{scroll-behavior:smooth}

body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--fb);
  font-weight:300;
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .35s ease,color .35s ease;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

h1,h2,h3{
  font-family:var(--fd);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-.01em;
}

/* ─── SKIP LINK ─── */
.skip-link{
  position:absolute;top:-100%;left:16px;
  background:var(--accent);color:#fff;
  padding:8px 16px;z-index:999;border-radius:4px;font-size:14px;
}
.skip-link:focus{top:8px}

/* ═══════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--page-px);
  background:var(--nav-bg);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--nav-border);
  transition:background .35s ease,border-color .35s ease;
}

.nav-logo{font-family:var(--fd);font-size:21px;font-weight:400;color:var(--fg);letter-spacing:.01em}

.nav-links{display:none;align-items:center;gap:36px;list-style:none}
.nav-links a{
  font-family:var(--fb);font-size:11px;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--fg-subtle);transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--fg)}

.nav-right{display:flex;align-items:center;gap:16px}

@media(min-width:1024px){
  .nav-links{display:flex}
  .nav-burger{display:none!important}
}

/* Theme toggle */
/* Burger */
.nav-burger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:210}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--fg);transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile overlay */
.mobile-nav{
  position:fixed;inset:0;z-index:205;
  background:rgba(28,25,21,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.mobile-nav.open{opacity:1;pointer-events:auto}
[data-theme="light"] .mobile-nav{background:rgba(240,238,233,.97)}

.mobile-nav a{font-family:var(--fd);font-size:32px;color:var(--fg);opacity:.6;transition:opacity .2s}
.mobile-nav a:hover,.mobile-nav a.active{opacity:1}

/* ═══════════════════════════════════════════
   HERO — Homepage split (full viewport)
   ═══════════════════════════════════════════ */
.hero{
  padding-top:64px;
  min-height:85vh;
  min-height:85dvh;
  display:grid;grid-template-columns:1fr;
}

.hero-panel{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  min-height:42vh;min-height:42dvh;
  padding:48px 0;
}
.hero-panel:first-child{background:var(--bg)}
.hero-panel:last-child{background:var(--bg2)}

.hero-panel::before{
  content:'';position:absolute;
  width:clamp(200px,30vw,400px);height:clamp(200px,30vw,400px);
  border:1px solid var(--accent);border-radius:50%;opacity:.06;pointer-events:none;
}
.hero-panel:first-child::before{right:-15%;top:-10%}
.hero-panel:last-child::before{left:-15%;bottom:-10%}

.panel-content{
  position:relative;z-index:2;
  padding:36px var(--page-px);
  display:flex;flex-direction:column;align-items:flex-start;gap:20px;
}
.panel-word{font-family:var(--fd);font-size:clamp(52px,12vw,130px);font-weight:400;line-height:.95;letter-spacing:-.02em;color:var(--fg)}
.panel-sub{font-family:var(--fb);font-size:14px;font-weight:300;line-height:1.7;color:var(--fg-muted);max-width:420px}

@media(min-width:1024px){
  .hero{grid-template-columns:1fr 1fr;min-height:85vh}
  .hero-panel{min-height:auto;padding:0}
  .hero-panel:first-child{border-right:1px solid var(--border)}
  .panel-content{padding:48px var(--page-px);gap:28px}
}

/* Hero panel with photo background */
.hero-panel--photo{background-size:cover!important;background-position:center top!important;background-repeat:no-repeat!important}
.hero-panel-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,rgba(28,25,21,.88) 0%,rgba(28,25,21,.65) 50%,rgba(28,25,21,.42) 100%)}
[data-theme="light"] .hero-panel-overlay{background:linear-gradient(135deg,rgba(240,238,233,.90) 0%,rgba(240,238,233,.70) 50%,rgba(240,238,233,.45) 100%)}
.hero-panel-overlay--darker{background:linear-gradient(135deg,rgba(28,25,21,.93) 0%,rgba(28,25,21,.78) 50%,rgba(28,25,21,.58) 100%)}
[data-theme="light"] .hero-panel-overlay--darker{background:linear-gradient(135deg,rgba(240,238,233,.85) 0%,rgba(240,238,233,.65) 50%,rgba(240,238,233,.45) 100%)}

/* Photo strip — full-width contained image on subpages */
.photo-strip{max-width:var(--site-max);margin:0 auto;padding:0 var(--page-px) 64px}
.photo-strip img{width:100%;max-height:480px;object-fit:cover;object-position:center 20%;border-radius:4px;display:block}
@media(min-width:768px){.photo-strip img{max-height:560px}}

/* About photo row — text + image side by side */
.about-photo-row{display:grid;grid-template-columns:1fr;gap:48px;align-items:start;margin-bottom:40px}
.about-photo-img img{width:100%;border-radius:4px;display:block;object-fit:cover;max-height:420px;object-position:center top}
@media(min-width:768px){.about-photo-row{grid-template-columns:1fr 1fr;gap:64px;align-items:center}}

/* ═══════════════════════════════════════════
   HERO — Subpage
   ═══════════════════════════════════════════ */
.subpage-hero{
  padding:140px var(--page-px) 80px;
  max-width:var(--site-max);margin:0 auto;
}
.subpage-hero h1{font-size:clamp(32px,5vw,56px);margin-bottom:18px;max-width:var(--content-max)}
.subpage-hero .hero-sub{font-size:16px;font-weight:300;line-height:1.7;color:var(--fg-muted);max-width:560px}

@media(min-width:1024px){.subpage-hero{padding:180px var(--page-px) 100px}}

.subpage-hero--photo{position:relative;background-size:cover;background-position:center;max-width:none;min-height:80vh;display:flex;flex-direction:column;justify-content:flex-end}
.subpage-hero--photo > :not(.subpage-hero-overlay){position:relative;z-index:1}
.subpage-hero--photo h1{max-width:none}
.subpage-hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);z-index:0}

/* ═══════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════ */
.btn{
  font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.13em;text-transform:uppercase;
  color:var(--fg);border:1px solid var(--border-strong);
  padding:13px 28px;border-radius:100px;display:inline-block;
  transition:background .25s,border-color .25s;cursor:pointer;background:transparent;
}
.btn:hover{background:var(--surface-hover);border-color:var(--fg-subtle)}

.btn--solid{color:var(--bg);background:var(--fg);border-color:var(--fg)}
.btn--solid:hover{background:var(--fg-muted);border-color:var(--fg-muted)}

.btn--orange{color:#fff;background:var(--accent);border-color:var(--accent)}
.btn--orange:hover{background:var(--accent-hover);border-color:var(--accent-hover)}

.link-arrow{
  font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.13em;text-transform:uppercase;
  color:var(--fg);display:inline-flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--border-mid);padding-bottom:4px;
  transition:gap .25s,border-color .25s;
}
.link-arrow::after{content:'\2192'}
.link-arrow:hover{gap:18px;border-color:var(--fg-subtle)}

/* ═══════════════════════════════════════════
   EYEBROW TAG
   ═══════════════════════════════════════════ */
.tag{
  font-family:var(--fb);font-size:10px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:24px;display:flex;align-items:center;gap:12px;
}
.tag::before{content:'';display:block;width:26px;height:1px;background:var(--accent)}

/* ═══════════════════════════════════════════
   INTRO (above ticker)
   ═══════════════════════════════════════════ */
.intro-section{background:var(--bg-inv);padding:80px var(--page-px) 48px;text-align:center;transition:background .35s ease}
.intro-inner{max-width:720px;margin:0 auto}
.intro-heading{font-family:var(--fd);font-size:clamp(24px,3.5vw,40px);font-weight:400;color:var(--fg-inv);line-height:1.2;margin:0}
.intro-avatar{margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:10px}
.intro-avatar img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--accent)}
.intro-avatar-name{font-family:var(--fd);font-size:16px;color:var(--fg)}
.social-icons--intro{gap:14px}
.social-icons--intro a{color:var(--fg-muted);transition:color .2s}
.social-icons--intro a:hover{color:var(--accent)}

/* ═══════════════════════════════════════════
   TICKER
   ═══════════════════════════════════════════ */
.ticker-wrap{background:var(--bg-inv);overflow:hidden;padding:50px 0;border-top:1px solid var(--border-inv);border-bottom:1px solid var(--border-inv);transition:background .35s ease}
.ticker-wrap--no-top{border-top:none}
.ticker-track{display:flex;width:max-content;animation:ticker 30s linear infinite}
.ticker-item{font-family:var(--fd);font-size:20px;color:var(--fg-inv-subtle);padding:0 52px;white-space:nowrap}
.ticker-sep{font-family:var(--fb);font-size:14px;color:var(--accent);align-self:center;flex-shrink:0;opacity:.9}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════
   TWO PATHS (homepage side-by-side)
   ═══════════════════════════════════════════ */
.two-paths{
  display:grid;grid-template-columns:1fr;gap:1px;
  background:var(--border);
  max-width:var(--site-max);margin:0 auto;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.path-card{background:var(--bg);padding:72px var(--page-px);display:flex;flex-direction:column;transition:background .35s ease}
.path-heading{font-family:var(--fd);font-size:clamp(24px,3.5vw,36px);font-weight:400;line-height:1.15;letter-spacing:-.01em;margin-bottom:20px}
.path-body{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);max-width:480px;margin-bottom:28px}
.path-body + .path-body{margin-top:-10px}
.path-card .link-arrow{margin-top:auto;align-self:flex-start}

@media(min-width:768px){.two-paths{grid-template-columns:1fr 1fr}.path-card{padding:80px 56px}}
@media(min-width:1024px){.path-card{padding:112px 64px}}

/* Shared text styles used across pages */
.story-h2{font-size:clamp(28px,4vw,44px);margin-bottom:22px}
.story-body{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);max-width:520px;margin-bottom:36px}
.story-body + .story-body{margin-top:-20px}

/* ═══════════════════════════════════════════
   FULL-BLEED SECTIONS — consistent padding
   All get --page-px padding + inner max-width
   ═══════════════════════════════════════════ */

/* Numbers — inverted */
.numbers-section{background:var(--bg-inv);padding:80px var(--page-px);transition:background .35s ease}
.numbers-inner{max-width:var(--content-max);margin:0 auto}

.numbers-heading{font-family:var(--fd);font-size:clamp(28px,4vw,48px);font-weight:400;line-height:1.15;letter-spacing:-.01em;color:var(--fg-inv);margin-bottom:56px}
.numbers-grid{display:grid;grid-template-columns:1fr;gap:40px;border-top:1px solid var(--border-inv);padding-top:40px}
.num-big{font-family:var(--fd);font-size:clamp(40px,6vw,56px);font-weight:400;line-height:1;color:var(--fg-inv);margin-bottom:10px;letter-spacing:-.03em}
.num-big b{color:var(--accent);font-weight:400}
.num-lbl{font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-inv-subtle)}

@media(min-width:768px){
  .numbers-grid{grid-template-columns:repeat(3,1fr);gap:0}
  .num-cell{padding:52px 0;border-right:1px solid var(--border-inv)}
  .num-cell + .num-cell{padding-left:52px}
  .num-cell:last-child{border-right:none}
  .numbers-section{padding:100px var(--page-px)}
}

/* Newsletter */
.nl-section{padding:80px var(--page-px);border-top:1px solid var(--border)}
.nl-inner{max-width:var(--site-max);margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
.nl-h2{font-size:clamp(24px,3.2vw,40px);line-height:1.15;margin-bottom:18px}
.nl-body{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted)}
.nl-cta{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.nl-fine{font-size:12px;color:var(--fg-subtle);letter-spacing:.04em;line-height:1.5}

@media(min-width:1024px){
  .nl-inner{grid-template-columns:1fr 1fr;gap:80px}
  .nl-section{padding:112px var(--page-px)}
}

/* Contact section — inverted */
.contact-section{background:var(--bg-inv);padding:80px var(--page-px);transition:background .35s ease}
.contact-section-inner{max-width:var(--content-max);margin:0 auto}
.contact-heading{font-family:var(--fd);font-size:clamp(32px,4vw,48px);font-weight:400;color:var(--fg-inv);margin-bottom:12px}
.contact-sub{font-size:16px;font-weight:300;color:var(--fg-inv-subtle);margin-bottom:48px}
.contact-section .tag{color:var(--accent)}.contact-section .tag::before{background:var(--accent)}

.contact-section .form-field--inv{color:var(--fg-inv);border-bottom-color:var(--border-inv-mid)}
.contact-section .form-field--inv:focus{border-bottom-color:var(--fg-inv-subtle)}
.contact-section .form-field--inv::placeholder{color:var(--fg-inv-faint)}
.contact-section .btn--filled{color:#fff;border-color:var(--accent)}

.contact-sidebar{display:flex;flex-direction:column;gap:44px}
.contact-sidebar-label{font-family:var(--fb);font-size:10px;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-inv-faint);margin-bottom:10px}
.contact-sidebar-email{font-size:16px;font-weight:300;color:var(--fg-inv)!important;transition:opacity .2s}
.contact-sidebar-email:hover{opacity:.6}

.social-icons{display:flex;gap:24px}
.social-icons a{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-inv);color:var(--fg-inv-subtle);transition:color .2s,border-color .2s,background .2s}
.social-icons a:hover{color:var(--fg-inv);border-color:var(--border-inv-mid);background:var(--surface-inv)}

.contact-section .btn{color:var(--fg-inv);border-color:var(--border-inv-mid)}
.contact-section .btn:hover{background:var(--surface-inv);border-color:var(--fg-inv-subtle)}

.contact-success-heading{font-family:var(--fd);font-size:28px;color:var(--fg-inv);margin-bottom:14px}
.contact-success-text{font-size:16px;font-weight:300;line-height:1.7;color:var(--fg-inv-muted);margin-bottom:18px}
.contact-success-fallback{font-size:14px;font-weight:300;color:var(--fg-inv-subtle)}
.contact-success-fallback a{color:var(--accent);text-decoration:underline}

@media(min-width:1024px){.contact-section{padding:100px var(--page-px)}}

/* CTA banner — inverted */
.cta-banner{padding:80px var(--page-px);text-align:center;background:var(--bg-inv);transition:background .35s ease}
.cta-banner h2{font-size:clamp(28px,4vw,48px);margin-bottom:14px;color:var(--fg-inv)}
.cta-banner p{font-size:15px;font-weight:300;color:var(--fg-inv-subtle);margin-bottom:32px}
.cta-banner .btn{color:var(--fg-inv);border-color:var(--border-inv-mid)}
.cta-banner .btn:hover{background:var(--surface-inv);border-color:var(--fg-inv-subtle)}

.cta-banner--dark{background:var(--bg)}
.cta-banner--dark h2{color:var(--fg)}
.cta-banner--dark p{color:var(--fg-muted)}
.cta-banner--dark .btn{color:var(--fg);border-color:var(--border-strong)}
.cta-banner--dark .btn:hover{background:var(--surface-hover);border-color:var(--fg-subtle)}

@media(min-width:1024px){.cta-banner{padding:112px var(--page-px)}}

/* References — inverted */
.references-section{padding:60px var(--page-px) 80px;background:var(--bg-inv);transition:background .35s ease}
.references-section .tag{color:var(--accent)}.references-section .tag::before{background:var(--accent)}
.references-section-inner{max-width:var(--content-max);margin:0 auto}
.references-list{display:flex;flex-wrap:wrap;gap:12px 24px;list-style:none}
.references-list li{font-size:14px;font-weight:300;color:var(--fg-inv-subtle)}

/* Process — inverted */
.process-section{padding:80px var(--page-px);background:var(--bg-inv);transition:background .35s ease}
.process-section-inner{max-width:var(--content-max);margin:0 auto}
.process-section .tag{color:var(--accent)}.process-section .tag::before{background:var(--accent)}
.process-section .story-h2{color:var(--fg-inv)}

.process-step{display:grid;grid-template-columns:48px 1fr;gap:20px;padding:32px 0;border-bottom:1px solid var(--border-inv)}
.step-num{font-family:var(--fd);font-size:32px;color:var(--accent);line-height:1}
.step-title{font-family:var(--fd);font-size:20px;color:var(--fg-inv);margin-bottom:8px;line-height:1.3}
.step-desc{font-size:15px;font-weight:300;line-height:1.7;color:var(--fg-inv-subtle)}

.process-section--dark{background:var(--bg)}
.process-section--dark .story-h2{color:var(--fg)}
.process-section--dark .step-title{color:var(--fg)}
.process-section--dark .step-desc{color:var(--fg-muted)}
.process-section--dark .process-step{border-bottom-color:var(--border)}

/* Timeline — inverted */
.timeline-section{padding:80px var(--page-px);background:var(--bg-inv);transition:background .35s ease}
.timeline-section-inner{max-width:var(--content-max);margin:0 auto}
.timeline-heading{font-size:clamp(24px,4vw,36px);line-height:1.2;color:var(--fg-inv);margin-bottom:16px}
.timeline-intro{font-size:16px;font-weight:300;line-height:1.7;color:var(--fg-inv-subtle);margin-bottom:56px;max-width:none}

.timeline{position:relative;padding-left:48px}
.timeline::before{content:'';position:absolute;left:15px;top:8px;bottom:8px;width:1px;background:var(--border-inv)}

.timeline-item{position:relative;padding-bottom:56px}
.timeline-item:last-child{padding-bottom:0}
.timeline-item::before{content:'';position:absolute;left:-48px;top:6px;width:32px;height:32px;border-radius:50%;background:var(--bg-inv);border:1px solid var(--border-inv-mid);z-index:1;transition:border-color .3s,box-shadow .3s}
.timeline-item::after{content:'';position:absolute;left:-39px;top:15px;width:14px;height:14px;border-radius:50%;background:var(--accent);z-index:2;transform:scale(.6);transition:transform .3s}
.timeline-item:hover::before{border-color:var(--accent);box-shadow:0 0 0 6px rgba(181,99,74,.15)}
.timeline-item:hover::after{transform:scale(1)}
.timeline-year{font-family:var(--fd);font-size:32px;color:var(--accent);line-height:1;margin-bottom:12px;letter-spacing:-.02em}
.timeline-title{font-family:var(--fd);font-size:20px;color:var(--fg-inv);margin-bottom:10px;line-height:1.3}
.timeline-text{font-size:15px;font-weight:300;line-height:1.7;color:var(--fg-inv-subtle);max-width:480px}
.timeline-tag{display:inline-block;margin-top:14px;padding:5px 14px;background:rgba(181,99,74,.12);color:var(--accent);font-size:12px;font-weight:400;border-radius:100px;letter-spacing:.03em}

@media(max-width:480px){
  .timeline{padding-left:40px}
  .timeline::before{left:11px}
  .timeline-item::before{left:-40px;width:24px;height:24px}
  .timeline-item::after{left:-34px;top:12px;width:10px;height:10px}
  .timeline-year{font-size:26px}
}

/* Portfolio — inverted */
.portfolio-section-light{background:var(--bg-inv);padding:80px var(--page-px);transition:background .35s ease}
.portfolio-section-inner{max-width:var(--site-max);margin:0 auto;padding-bottom:48px}
.portfolio-section-light .tag{color:var(--accent)}.portfolio-section-light .tag::before{background:var(--accent)}
.portfolio-heading{font-family:var(--fd);font-size:clamp(28px,4vw,44px);font-weight:400;color:var(--fg-inv);line-height:1.05}

.portfolio-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:var(--site-max);margin:0 auto}
.portfolio-item{position:relative;overflow:hidden;background:var(--surface-inv);border:1px solid var(--border-inv);border-radius:4px;min-height:240px;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;text-decoration:none}
.portfolio-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.55) 45%,rgba(0,0,0,.15) 80%)}
.portfolio-item-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.portfolio-item-name{position:relative;z-index:1;font-family:var(--fd);font-size:22px;margin-bottom:6px;color:#fff}
.portfolio-item-desc{position:relative;z-index:1;font-size:13px;font-weight:300;color:rgba(255,255,255,.75)}

@media(min-width:768px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}

/* ═══════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════ */
.form-field{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border-mid);color:var(--fg);font-family:var(--fb);font-size:16px;font-weight:300;padding:14px 0;outline:none;transition:border-color .2s;-webkit-appearance:none;border-radius:0}
.form-field:focus{border-color:var(--fg-subtle)}
.form-field::placeholder{color:var(--fg-faint)}
textarea.form-field{resize:vertical;min-height:120px;line-height:1.6}

select.form-field{color:var(--fg-faint);cursor:pointer;background:var(--bg)}
select.form-field:valid:not([value=""]){color:var(--fg)}
select.form-field option{background:var(--bg2);color:var(--fg)}

.form-field--inv{color:var(--fg-inv);border-bottom-color:var(--border-inv-mid);background:transparent}
.form-field--inv:focus{border-bottom-color:var(--fg-inv-subtle)}
.form-field--inv::placeholder{color:var(--fg-inv-faint)}

.form-field--box{border:1px solid var(--border-inv-mid);border-radius:8px;padding:14px 16px;background:var(--bg-inv);color:var(--fg-inv);font-size:15px}
.form-field--box:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(181,99,74,.12)}
.form-field--box::placeholder{color:var(--fg-inv-faint)}
select.form-field--box{color:var(--fg-inv-faint);cursor:pointer;background:var(--bg-inv);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9080' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
select.form-field--box:valid:not([value=""]){color:var(--fg-inv)}
select.form-field--box option{background:var(--bg-inv);color:var(--fg-inv)}

.btn--filled{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500}
.btn--filled:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn--dark{color:var(--fg-inv);border-color:var(--fg-inv-muted)}
.btn--dark:hover{background:var(--surface-inv);border-color:var(--fg-inv)}

/* ═══════════════════════════════════════════
   PRODUCT CARDS
   ═══════════════════════════════════════════ */
.product-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:var(--site-max);margin:0 auto}
@media(min-width:768px){.product-grid{grid-template-columns:1fr 1fr}}

.variant-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:var(--site-max);margin:0 auto}
@media(min-width:768px){.variant-grid{grid-template-columns:repeat(3,1fr)}}

.product-card{padding:60px 0;border-bottom:1px solid var(--border)}

.product-card--box{
  background:var(--bg2);color:var(--fg);
  border:1px solid var(--border-mid);border-radius:6px;
  padding:28px;margin-bottom:0;
  transition:background .35s ease,border-color .35s ease;
  display:flex;flex-direction:column;
}
.product-card--box h3{color:var(--fg)}
.product-card--box .tag{color:var(--accent)}.product-card--box .tag::before{background:var(--accent)}
.product-card--box .product-desc{color:var(--fg-muted)}
.product-card--box .product-for{color:var(--fg-subtle);border-left-color:var(--accent)}
.product-card--box .product-list li{color:var(--fg-muted)}
.product-card--box .product-list li::before{background:var(--accent)}
.product-card--box .product-logistics{color:var(--fg-subtle)}
.product-card--box .btn{color:var(--fg);border-color:var(--border-strong);margin-top:auto}
.product-card--box .btn:hover{background:var(--surface-hover);border-color:var(--fg-subtle)}

.product-card--featured{border-color:var(--accent);position:relative}
.product-badge{position:absolute;top:16px;right:16px;font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--accent);color:#fff;padding:5px 12px;border-radius:100px}

@media(min-width:768px){.product-card--box{padding:36px 40px}}

.product-card h3{font-size:clamp(22px,3vw,32px);margin-bottom:18px}
.product-desc{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);margin-bottom:24px}
.product-for{font-size:14px;font-weight:300;line-height:1.7;color:var(--fg-subtle);margin-bottom:32px;padding-left:16px;border-left:2px solid var(--accent)}
.product-list{list-style:none;margin-bottom:36px}
.product-list li{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);padding-left:20px;position:relative}
.product-list li::before{content:'';position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.product-logistics{font-size:13px;font-weight:300;letter-spacing:.05em;color:var(--fg-subtle);margin-bottom:28px}
.product-sub{font-size:16px;font-weight:300;color:var(--fg-muted);margin-bottom:24px}

/* Training section */
.training-section{padding:80px var(--page-px)}
.training-inner{max-width:var(--content-max);margin:0 auto}
.training-curriculum{list-style:none;counter-reset:curriculum;margin-bottom:32px}
.training-curriculum li{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);padding-left:32px;position:relative;margin-bottom:8px;counter-increment:curriculum}
.training-curriculum li::before{content:counter(curriculum,decimal-leading-zero) ".";position:absolute;left:0;color:var(--accent);font-weight:400;font-size:13px}
.training-formats{display:grid;grid-template-columns:1fr;gap:24px}
.training-format{border:1px solid var(--border);border-radius:8px;padding:32px;display:flex;flex-direction:column}
.training-format h4{font-family:var(--fd);font-size:18px;margin-bottom:20px}
.training-format ul{list-style:none;margin-bottom:28px;flex:1}
.training-format ul li{font-size:14px;font-weight:300;line-height:1.8;color:var(--fg-muted);padding-left:18px;position:relative}
.training-format ul li::before{content:'';position:absolute;left:0;top:11px;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.training-format--featured{border-color:var(--accent)}
.training-process{display:flex;flex-direction:column;gap:24px}
.training-clients{list-style:none}
.training-clients li{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);margin-bottom:12px}
.training-clients li strong{color:var(--fg);font-weight:400}
@media(min-width:768px){.training-formats{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.training-section{padding:100px var(--page-px)}}

/* Services grid */
.services-grid{display:grid;grid-template-columns:1fr;gap:40px;max-width:var(--site-max);margin:0 auto;padding:0 var(--page-px)}
.service-card{padding:40px 0;border-top:1px solid var(--border)}
.service-card h3{font-size:clamp(22px,2.5vw,28px);margin-bottom:14px}
.service-card p{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);max-width:380px}
.service-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.service-tags span{font-size:11px;font-weight:400;color:var(--fg-muted);border:1px solid var(--accent);background:var(--surface);padding:4px 10px;border-radius:4px;line-height:1}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(3,1fr);gap:52px}}

/* Longterm */
.longterm-section{padding:80px var(--page-px)}
.longterm-inner{max-width:var(--content-max);margin-left:auto;margin-right:auto}
.longterm-inner .story-body{max-width:none}
.longterm-list{list-style:none;margin-top:40px}
.longterm-list li{font-size:15px;font-weight:300;line-height:1.8;color:var(--fg-muted);padding-left:20px;position:relative;margin-bottom:10px}
.longterm-list li::before{content:'';position:absolute;left:0;top:12px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
@media(min-width:1024px){.longterm-section{padding:100px var(--page-px)}}

/* ═══════════════════════════════════════════
   SECTION UTILITIES
   ═══════════════════════════════════════════ */
.section-padded{padding:80px var(--page-px);max-width:var(--site-max);margin:0 auto}
.section-wide{padding:80px var(--page-px);max-width:var(--site-max);margin:0 auto}
@media(min-width:1024px){.section-padded{padding:100px var(--page-px)}}

/* ═══════════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════════ */
.about-text{max-width:680px;margin:0 auto;padding:0 var(--page-px) 80px}
.about-text p{font-size:16px;font-weight:300;line-height:1.85;color:var(--fg-muted);margin-bottom:28px}
.about-text p:first-child{font-size:18px;font-weight:400;color:var(--fg);line-height:1.7}
.about-socials{display:flex;justify-content:center;gap:36px;padding-bottom:60px}
.about-socials a{font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-subtle);transition:color .2s}
.about-socials a:hover{color:var(--fg)}

/* ═══════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════ */
.contact-grid{max-width:var(--site-max);margin:0 auto;padding:0 var(--page-px) 80px;display:grid;grid-template-columns:1fr;gap:48px}
.contact-form{display:flex;flex-direction:column;gap:24px}
.contact-info{font-size:14px;font-weight:300;color:var(--fg-subtle);line-height:1.8}
.contact-info strong{color:var(--fg);font-weight:400}
.contact-info a{color:var(--fg);transition:opacity .2s}
.contact-info a:hover{opacity:.7}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 280px;gap:80px}}

/* ═══════════════════════════════════════════
   LEGAL PAGES
   ═══════════════════════════════════════════ */
.legal-content{max-width:var(--content-max);margin:0 auto;padding:0 var(--page-px) 100px}
.legal-intro{font-size:16px;font-weight:300;line-height:1.85;color:var(--fg-muted);margin-bottom:56px;font-style:italic;border-left:2px solid var(--accent);padding-left:20px}
.legal-section{margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid var(--border)}
.legal-section:last-child{border-bottom:none;padding-bottom:0}
.legal-section h2{font-size:clamp(18px,2.5vw,22px);margin-bottom:20px;color:var(--fg);letter-spacing:.01em}
.legal-section h3{font-size:16px;margin-bottom:12px;margin-top:32px;color:var(--fg);letter-spacing:.01em}
.legal-section p{font-size:15px;font-weight:300;line-height:1.85;color:var(--fg-muted);margin-bottom:16px}
.legal-section ul{list-style:none;margin-bottom:16px}
.legal-section li{font-size:15px;font-weight:300;line-height:1.85;color:var(--fg-muted);padding-left:20px;position:relative;margin-bottom:8px}
.legal-section li::before{content:'';position:absolute;left:0;top:12px;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.7}
.legal-section li strong{color:var(--fg);font-weight:400}
.legal-section a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
footer{border-top:1px solid var(--border);padding:28px var(--page-px);display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center;transition:border-color .35s ease}
.f-logo{font-family:var(--fd);font-size:18px;font-weight:400;color:var(--fg)}
.f-links{display:flex;gap:28px;list-style:none}
.f-links a{font-family:var(--fb);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);transition:color .2s}
.f-links a:hover{color:var(--fg-muted)}
.f-copy{font-family:var(--fb);font-size:11px;letter-spacing:.04em;color:var(--fg-subtle)}
.f-legal{display:flex;gap:20px;list-style:none}
.f-legal a{font-family:var(--fb);font-size:11px;letter-spacing:.04em;color:var(--fg-subtle);transition:color .2s}
.f-legal a:hover{color:var(--fg)}
@media(min-width:768px){footer{flex-direction:row;flex-wrap:nowrap;justify-content:space-between;align-items:center;padding:36px var(--page-px)}}

/* ═══════════════════════════════════════════
   REVEAL ANIMATIONS
   ═══════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1.2s cubic-bezier(0.16,1,0.3,1),transform 1.2s cubic-bezier(0.16,1,0.3,1)}
.reveal.on{opacity:1;transform:none}
.reveal-d1{transition-delay:.15s}
.reveal-d2{transition-delay:.3s}

/* ═══════════════════════════════════════════
   COOKIE BANNER (always dark)
   ═══════════════════════════════════════════ */
.cookie-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-40%);opacity:0;pointer-events:none;z-index:300;background:#252119;border:1px solid rgba(213,203,186,.15);border-radius:16px;padding:28px 32px;display:flex;flex-direction:column;gap:20px;width:min(520px,calc(100vw - 32px));box-shadow:0 8px 40px rgba(0,0,0,.45);transition:transform .4s cubic-bezier(0.16,1,0.3,1),opacity .4s ease}
.cookie-banner.visible{transform:translate(-50%,-50%);opacity:1;pointer-events:auto}
.cookie-banner-heading{font-family:var(--fh);font-size:18px;font-weight:400;color:#D5CBBA;margin:0 0 6px}
.cookie-banner-text{font-size:14px;font-weight:300;line-height:1.6;color:rgba(213,203,186,.75)}
.cookie-banner-text a{color:#D5CBBA;text-decoration:underline}
.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;padding:12px 26px;border-radius:100px;cursor:pointer;transition:background .2s,border-color .2s}
.cookie-btn--accept{background:#D5CBBA;color:#1C1915;border:1px solid #D5CBBA}
.cookie-btn--accept:hover{background:#C4B9A6;border-color:#C4B9A6}
.cookie-btn--necessary{background:transparent;color:#D5CBBA;border:1px solid rgba(213,203,186,.3)}
.cookie-btn--necessary:hover{background:rgba(213,203,186,.08);border-color:rgba(213,203,186,.5)}
.cookie-btn--settings{background:transparent;color:rgba(213,203,186,.55);border:1px solid rgba(213,203,186,.25);font-size:10px}
.cookie-btn--settings:hover{color:#D5CBBA;border-color:rgba(213,203,186,.3)}
.cookie-settings{display:none;padding-top:16px;border-top:1px solid rgba(213,203,186,.08);margin-top:4px}
.cookie-settings.open{display:block}
.cookie-option{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(213,203,186,.05)}
.cookie-option-label{font-size:13px;font-weight:300;color:rgba(213,203,186,.55)}
.cookie-option-label strong{color:#D5CBBA;font-weight:400}
.cookie-toggle{position:relative;width:40px;height:22px;flex-shrink:0}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle-track{position:absolute;inset:0;background:rgba(213,203,186,.12);border-radius:11px;cursor:pointer;transition:background .2s}
.cookie-toggle-track::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:#D5CBBA;border-radius:50%;transition:transform .2s}
.cookie-toggle input:checked + .cookie-toggle-track{background:var(--accent)}
.cookie-toggle input:checked + .cookie-toggle-track::after{transform:translateX(18px)}
.cookie-toggle input:disabled + .cookie-toggle-track{opacity:.4;cursor:not-allowed}

/* ═══════════════════════════════════════════
   SCROLLBAR
   ═══════════════════════════════════════════ */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--scrollbar-bg)}
::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:2px}
