:root{
  --color-bg: #f5f2ec;
  --color-bg-alt: #ede7db;
  --color-surface: #ffffff;
  --color-ink: #1f2622;
  --color-ink-soft: #4a534d;
  --color-dark: #1c2420;
  --color-dark-soft: #263029;
  --color-primary: #1f4d3f;
  --color-primary-light: #2f6b57;
  --color-accent: #d97b3f;
  --color-accent-soft: #f0d6ba;
  --color-border: #dcd4c4;
  --color-border-dark: #33403a;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;

  --shadow-tight: 0 1px 2px rgba(31,38,34,0.06), 0 2px 6px rgba(31,38,34,0.05);
  --shadow-raised: 0 4px 10px rgba(31,38,34,0.06), 0 12px 28px rgba(31,38,34,0.08);
  --shadow-floating: 0 8px 20px rgba(31,38,34,0.08), 0 24px 48px rgba(31,38,34,0.10);

  --transition-base: 0.25s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Work Sans', sans-serif;
  background:var(--color-bg);
  color:var(--color-ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

body.dark{
  --color-bg:#161c19;
  --color-bg-alt:#1c2420;
  --color-surface:#1f2925;
  --color-ink:#eef0ec;
  --color-ink-soft:#b9c2bb;
  --color-border:#33403a;
}

img{max-width:100%; display:block;}

.text-display{
  font-weight:700;
  letter-spacing:-0.02em;
  line-height:1.08;
  color:var(--color-ink);
  margin:0;
}
.text-body{
  font-size:1.05rem;
  color:var(--color-ink-soft);
  line-height:1.75;
  margin:0 0 1rem 0;
}
.text-caption{
  font-size:0.85rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--color-primary);
}

.surface{background:var(--color-bg);}
.surface-alt{background:var(--color-bg-alt);}
.surface-raised{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  border:1px solid var(--color-border);
  box-shadow:var(--shadow-raised);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.surface-dark{background:var(--color-dark); color:#eef0ec;}
.surface-inset{background:var(--color-bg-alt); border-radius:var(--radius-sm);}

.action-primary{
  display:inline-flex;
  align-items:center;
  gap:0.6rem;
  background:var(--color-primary);
  color:#fdfbf6;
  font-weight:600;
  padding:0.9rem 1.9rem;
  border-radius:var(--radius-sm);
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition:background var(--transition-base), transform var(--transition-base);
  min-height:44px;
  font-size:0.98rem;
}
.action-primary:hover{background:var(--color-accent); transform:translateY(-2px);}

.action-ghost{
  display:inline-flex;
  align-items:center;
  gap:0.6rem;
  background:transparent;
  color:var(--color-primary);
  font-weight:600;
  padding:0.9rem 1.5rem;
  border-radius:var(--radius-sm);
  border:2px solid var(--color-primary);
  cursor:pointer;
  text-decoration:none;
  transition:background var(--transition-base), color var(--transition-base);
  min-height:44px;
}
.action-ghost:hover{background:var(--color-primary); color:#fff;}

.action-ghost-light{
  display:inline-flex;
  align-items:center;
  gap:0.6rem;
  background:transparent;
  color:#fdfbf6;
  font-weight:600;
  padding:0.9rem 1.5rem;
  border-radius:var(--radius-sm);
  border:2px solid rgba(253,251,246,0.4);
  cursor:pointer;
  text-decoration:none;
  transition:background var(--transition-base), border-color var(--transition-base);
  min-height:44px;
}
.action-ghost-light:hover{background:rgba(253,251,246,0.12); border-color:#fdfbf6;}

.space-section{padding:var(--space-2xl) var(--space-md);}
.space-card{padding:var(--space-md);}

.section-inner{max-width:1180px; margin:0 auto; position:relative;}
.section-inner.narrow{max-width:760px;}

.section-head{max-width:680px; margin-bottom:var(--space-xl);}
.section-title{font-size:clamp(1.8rem, 3.2vw, 2.6rem); margin:0.6rem 0 1rem 0;}
.section-title-light{font-size:clamp(1.8rem, 3.2vw, 2.6rem); margin:0.6rem 0 1rem 0; color:#fdfbf6;}
.section-desc{max-width:600px;}
.accent-label{color:var(--color-accent); display:inline-block; margin-bottom:0.4rem;}
.accent-label-light{color:var(--color-accent-soft); display:inline-block; margin-bottom:0.4rem; font-size:0.85rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;}
.text-light-body{color:#c7ceca;}


.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--color-bg);
  border-bottom:1px solid var(--color-border);
  transition:transform var(--transition-base), opacity var(--transition-base);
}
.site-header.hide-header{transform:translateY(-120%); opacity:0;}

.nav-wrap{max-width:1280px; margin:0 auto; padding:0 1.5rem;}
.nav-full{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.1rem 0;
}
.nav-side{display:flex; align-items:center; gap:1.6rem;}
.nav-left{justify-content:flex-start;}
.nav-right{justify-content:flex-end;}
.nav-link{
  color:var(--color-ink);
  text-decoration:none;
  font-weight:500;
  font-size:0.98rem;
  position:relative;
  padding:0.4rem 0;
  transition:color var(--transition-base);
}
.nav-link::after{
  content:'';
  position:absolute;
  bottom:0; left:0;
  width:0; height:2px;
  background:var(--color-accent);
  transition:width var(--transition-base);
}
.nav-link:hover, .nav-link.active{color:var(--color-primary);}
.nav-link:hover::after, .nav-link.active::after{width:100%;}

.nav-logo{
  display:flex;
  align-items:center;
  gap:0.6rem;
  text-decoration:none;
  flex-shrink:0;
}
.nav-logo-mark{
  width:42px; height:42px;
  background:var(--color-primary);
  color:#fff;
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  font-weight:700;
  font-size:0.95rem;
}
.nav-logo-text{font-weight:700; font-size:1.15rem; color:var(--color-ink); white-space:nowrap;}

.nav-cta{padding:0.65rem 1.3rem; font-size:0.9rem;}

.dark-toggle{
  width:44px; height:44px;
  border-radius:50%;
  border:1px solid var(--color-border);
  background:var(--color-surface);
  color:var(--color-ink);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background var(--transition-base), color var(--transition-base);
}
.dark-toggle:hover{background:var(--color-primary); color:#fff;}

.mobile-open-btn{
  display:none;
  width:44px; height:44px;
  border-radius:var(--radius-sm);
  border:1px solid var(--color-border);
  background:var(--color-surface);
  color:var(--color-ink);
  cursor:pointer;
  align-items:center;
  justify-content:center;
}


.mini-pill{
  position:fixed;
  top:1.2rem;
  left:50%;
  transform:translateX(-50%) translateY(-140%);
  z-index:110;
  background:var(--color-primary);
  border-radius:999px;
  box-shadow:var(--shadow-floating);
  transition:transform var(--transition-base);
}
.mini-pill.visible{transform:translateX(-50%) translateY(0);}
.mini-pill button{
  width:56px; height:56px;
  border-radius:50%;
  border:none;
  background:transparent;
  color:#fff;
  font-size:1.2rem;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}


.mobile-overlay{
  position:fixed;
  inset:0;
  background:linear-gradient(160deg, var(--color-primary), var(--color-dark));
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity 0.4s ease;
}
.mobile-overlay.open{opacity:1; visibility:visible;}
.mobile-nav{display:flex; flex-direction:column; align-items:center; gap:1.6rem;}
.mobile-nav a{
  color:#fdfbf6;
  text-decoration:none;
  font-size:clamp(1.6rem, 6vw, 2.6rem);
  font-weight:600;
  transition:color var(--transition-base), transform var(--transition-base);
}
.mobile-nav a:hover{color:var(--color-accent-soft); transform:translateX(6px);}
.mobile-close{
  position:absolute;
  top:2rem; right:2rem;
  width:50px; height:50px;
  background:rgba(255,255,255,0.12);
  border:none;
  border-radius:50%;
  color:#fff;
  font-size:1.8rem;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}


.hero-section{position:relative; overflow:hidden;}
.hero-shape{
  position:absolute;
  width:420px; height:420px;
  border-radius:50%;
  background:var(--color-accent-soft);
  top:-140px; right:-120px;
  z-index:0;
  opacity:0.6;
}
.hero-shape-2{
  width:260px; height:260px;
  background:var(--color-primary);
  opacity:0.08;
  top:auto; bottom:-80px; left:-80px; right:auto;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:3.5rem;
  align-items:center;
  position:relative;
  z-index:1;
  padding-top:2rem;
  padding-bottom:2rem;
}
.hero-eyebrow{display:inline-block; margin-bottom:1rem;}
.hero-title{font-size:clamp(2.4rem, 5vw, 3.6rem); margin-bottom:1.3rem;}
.hero-desc{font-size:1.1rem; max-width:540px;}
.hero-actions{display:flex; gap:1rem; flex-wrap:wrap; margin:1.6rem 0;}
.hero-meta{display:flex; gap:1.8rem; flex-wrap:wrap; margin-top:1rem;}
.hero-meta-item{display:flex; align-items:center; gap:0.5rem; font-size:0.92rem; color:var(--color-ink-soft); font-weight:500;}
.hero-meta-item i{color:var(--color-accent);}

.hero-cards{position:relative; height:460px;}
.hero-card{
  position:absolute;
  width:280px;
  padding:1.6rem;
}
.hero-card i{font-size:1.6rem; color:var(--color-accent); margin-bottom:0.8rem; display:block;}
.hero-card h3{font-size:1.05rem; font-weight:700; margin:0 0 0.5rem 0; color:var(--color-ink);}
.hero-card p{font-size:0.9rem; color:var(--color-ink-soft); margin:0; line-height:1.55;}
.hero-card-1{top:0; right:40px; transform:rotate(-4deg); z-index:3;}
.hero-card-2{top:150px; right:120px; transform:rotate(3deg); z-index:2;}
.hero-card-3{top:300px; right:20px; transform:rotate(-2deg); z-index:1;}
.hero-card:hover{transform:translateY(-6px) rotate(0deg); box-shadow:var(--shadow-floating);}


.overlap-top{margin-top:-4rem; border-top-left-radius:var(--radius-xl); border-top-right-radius:var(--radius-xl); position:relative; z-index:2;}
.overlap-bottom{margin-bottom:-4rem; padding-bottom:calc(var(--space-2xl) + 4rem); border-bottom-left-radius:var(--radius-xl); border-bottom-right-radius:var(--radius-xl);}


.problem-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:1.5rem;}
.problem-card{padding:2rem 1.6rem;}
.problem-num{font-size:2rem; font-weight:700; color:var(--color-accent-soft); margin-bottom:0.6rem;}
.problem-card h3{font-size:1.1rem; margin:0 0 0.6rem 0; color:var(--color-ink);}
.problem-card:hover{transform:translateY(-6px);}


.steps-row{display:flex; align-items:stretch; gap:1rem;}
.step-card{flex:1; padding:2.2rem 1.8rem; position:relative;}
.step-number{
  width:44px; height:44px;
  border-radius:50%;
  background:var(--color-primary);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700;
  margin-bottom:1.2rem;
}
.step-icon{font-size:1.6rem; color:var(--color-accent); margin-bottom:1rem; display:block;}
.step-card h3{font-size:1.2rem; margin:0 0 0.6rem 0;}
.step-connector{display:flex; align-items:center; color:var(--color-border); font-size:1.4rem;}
.step-card:hover{transform:translateY(-6px);}


.image-section{overflow:hidden;}
.image-grid{display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center;}
.image-grid.reverse{direction:rtl;}
.image-grid.reverse > *{direction:ltr;}
.image-block img.image-styled{
  border-radius:var(--radius-lg);
  width:100%;
  height:420px;
  object-fit:cover;
  box-shadow:var(--shadow-floating);
}
.content-image{border-radius:var(--radius-md); height:340px; object-fit:cover; margin-top:1.5rem;}


.audience-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem; margin-bottom:2.5rem;}
.audience-card{padding:2.2rem 1.8rem; text-align:left;}
.audience-card i{font-size:1.8rem; color:var(--color-accent); margin-bottom:1rem; display:block;}
.audience-card h3{font-size:1.15rem; margin:0 0 0.6rem 0;}
.audience-card:hover{transform:translateY(-6px);}

.portrait-strip{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.2rem;}
.portrait-img{border-radius:var(--radius-md); height:240px; object-fit:cover; box-shadow:var(--shadow-raised);}


.faq-list{display:flex; flex-direction:column; gap:1rem; max-width:820px; margin:0 auto;}
.faq-item{overflow:hidden;}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.5rem 1.8rem;
  background:transparent;
  border:none;
  cursor:pointer;
  text-align:left;
  font-size:1.05rem;
  font-weight:600;
  color:var(--color-ink);
  gap:1rem;
}
.faq-icon{transition:transform var(--transition-base); color:var(--color-accent); flex-shrink:0;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-answer{max-height:0; overflow:hidden; transition:max-height 0.35s ease, padding var(--transition-base);}
.faq-answer p{padding:0 1.8rem 1.6rem 1.8rem; margin:0;}
.faq-item.open .faq-answer{max-height:400px;}


.cta-section{text-align:center; overflow:hidden; position:relative;}
.cta-inner{max-width:760px; margin:0 auto;}
.cta-title{font-size:clamp(1.8rem, 4vw, 2.6rem); color:#fdfbf6; margin-bottom:1.2rem;}
.cta-desc{max-width:560px; margin:0 auto 1.6rem auto;}
.cta-inner .hero-actions{justify-content:center;}


.site-footer{padding:var(--space-2xl) var(--space-md) 0 var(--space-md);}
.footer-inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:3rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--color-border-dark);
}
.footer-logo{margin-bottom:1.4rem;}
.footer-logo .nav-logo-text{color:#fdfbf6;}
.footer-story{max-width:440px; margin-bottom:1.5rem;}
.footer-links{display:grid; grid-template-columns:repeat(3, 1fr); gap:2rem;}
.footer-col h4{color:#fdfbf6; font-size:0.95rem; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:1rem;}
.footer-col a{display:block; color:#c7ceca; text-decoration:none; margin-bottom:0.7rem; transition:color var(--transition-base);}
.footer-col a:hover{color:var(--color-accent-soft);}
.footer-col p{margin-bottom:0.6rem; font-size:0.92rem;}
.footer-col p i{color:var(--color-accent-soft); margin-right:0.5rem;}
.footer-bottom{max-width:1180px; margin:0 auto; padding:1.6rem 0; text-align:center; font-size:0.85rem; color:#93a19a;}


.page-hero{padding:var(--space-2xl) var(--space-md) var(--space-xl) var(--space-md); position:relative; overflow:hidden;}
.page-hero-title{font-size:clamp(2.2rem, 4.5vw, 3.2rem); margin:0.8rem 0 1rem 0; max-width:760px;}
.page-hero-desc{max-width:640px; font-size:1.08rem;}


.shift-list{display:flex; flex-direction:column; gap:2rem;}
.shift-item{display:flex; gap:1.5rem; align-items:flex-start;}
.shift-num{font-size:1.6rem; font-weight:700; color:var(--color-accent); flex-shrink:0; width:60px;}
.shift-item h3{margin:0 0 0.5rem 0; font-size:1.2rem;}


.timeline{display:flex; flex-direction:column; gap:1.5rem;}
.timeline-item{display:flex; gap:1.8rem; padding:2rem; align-items:flex-start;}
.timeline-marker{
  width:52px; height:52px;
  border-radius:50%;
  background:var(--color-primary);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700;
  font-size:1.2rem;
  flex-shrink:0;
}
.timeline-content h3{margin:0.3rem 0 0.6rem 0; font-size:1.25rem;}


.format-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:1.5rem;}
.format-card{padding:2rem 1.5rem; text-align:center;}
.format-card i{font-size:1.7rem; color:var(--color-accent); margin-bottom:1rem; display:block;}
.format-card h3{font-size:1.05rem; margin:0 0 0.6rem 0;}
.format-card:hover{transform:translateY(-6px);}


.terms-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:1.5rem;}
.term-card{padding:2rem;}
.term-top{display:flex; justify-content:space-between; align-items:center; margin-bottom:1rem;}
.term-tag{font-weight:700; color:var(--color-primary); font-size:0.9rem; text-transform:uppercase; letter-spacing:0.05em;}
.term-status{font-size:0.8rem; font-weight:600; padding:0.3rem 0.8rem; border-radius:999px;}
.status-open{background:#dcefe2; color:#1f6b3f;}
.status-limited{background:#faf0d9; color:#a5680f;}
.status-planned{background:#e6e6e6; color:#5a5a5a;}
.term-card h3{margin:0 0 1rem 0; font-size:1.25rem;}
.term-meta p{margin:0.3rem 0; font-size:0.92rem; color:var(--color-ink-soft);}
.term-meta{margin-bottom:1rem;}
.term-meta i{color:var(--color-accent); margin-right:0.5rem; width:16px;}
.term-cta{margin-top:1.2rem; width:100%; justify-content:center;}


.contact-grid{display:grid; grid-template-columns:0.9fr 1.4fr; gap:2.5rem;}
.contact-info-col{display:flex; flex-direction:column; gap:1.2rem;}
.info-card{display:flex; align-items:center; gap:1.2rem; padding:1.4rem 1.6rem;}
.info-card i{font-size:1.3rem; color:var(--color-accent); width:32px;}
.info-card h4{margin:0 0 0.2rem 0; font-size:0.95rem;}
.info-card p{margin:0;}
.map-wrap{overflow:hidden; padding:0;}
.map-wrap iframe{display:block; border-radius:var(--radius-md);}

.contact-form-col{padding:2.5rem;}
.form-row{margin-bottom:1.2rem; display:flex; flex-direction:column; gap:0.5rem;}
.form-row label{font-weight:600; font-size:0.92rem; color:var(--color-ink);}
.form-row input, .form-row textarea{
  padding:0.85rem 1rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--color-border);
  font-family:inherit;
  font-size:1rem;
  background:var(--color-bg);
  color:var(--color-ink);
  transition:border-color var(--transition-base);
  min-height:44px;
}
.form-row input:focus, .form-row textarea:focus{outline:none; border-color:var(--color-primary);}
.checkbox-row{flex-direction:row; align-items:flex-start; gap:0.8rem;}
.checkbox-row input{min-height:auto; width:22px; height:22px; flex-shrink:0; margin-top:2px;}
.checkbox-row label{font-weight:400; font-size:0.9rem; color:var(--color-ink-soft);}
.checkbox-row a{color:var(--color-primary);}
.form-submit{width:100%; justify-content:center; margin-top:0.5rem;}


.news-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem;}
.news-card{padding:1.8rem;}
.news-date{color:var(--color-accent); font-weight:700; font-size:0.85rem; text-transform:uppercase; letter-spacing:0.05em;}
.news-card h3{margin:0.6rem 0; font-size:1.1rem;}
.news-card:hover{transform:translateY(-6px);}


.thanks-section{min-height:60vh; display:flex; align-items:center;}
.thanks-inner{text-align:center;}
.thanks-icon{font-size:3.5rem; color:var(--color-primary); margin-bottom:1rem;}
.thanks-desc{max-width:560px; margin:0 auto 2rem auto;}
.next-steps{text-align:left; max-width:560px; margin:0 auto 2rem auto; background:var(--color-bg-alt); padding:2rem; border-radius:var(--radius-md);}
.next-step-item{display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.2rem;}
.next-step-item i{color:var(--color-accent); font-size:1.3rem; margin-top:0.2rem;}
.next-step-item p{margin:0;}


.legal-page{padding-top:var(--space-2xl);}
.legal-intro{margin-bottom:2rem;}
.legal-summary{
  background:var(--color-accent-soft);
  color:#7a4718;
  font-weight:600;
  padding:1rem 1.4rem;
  border-radius:var(--radius-sm);
  margin:2rem 0 0.8rem 0;
  font-size:0.95rem;
}
.legal-section{margin-bottom:1.5rem;}
.legal-section h2{font-size:1.25rem; margin:0 0 0.6rem 0;}


.cookie-link{
  position:fixed;
  bottom:1.2rem;
  left:1.2rem;
  z-index:150;
  background:var(--color-surface);
  border:1px solid var(--color-border);
  color:var(--color-ink-soft);
  padding:0.6rem 1rem;
  border-radius:999px;
  font-size:0.82rem;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:0.5rem;
  box-shadow:var(--shadow-tight);
  transition:background var(--transition-base), color var(--transition-base);
}
.cookie-link:hover{background:var(--color-primary); color:#fff;}
.cookie-link.pulse{animation:cookiePulse 1.8s ease-in-out 2;}
@keyframes cookiePulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.06);}
}

.cookie-modal{
  position:fixed;
  inset:0;
  background:rgba(20,24,22,0.55);
  z-index:250;
  display:none;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
}
.cookie-modal.open{display:flex;}
.cookie-modal-inner{
  max-width:480px;
  width:100%;
  padding:2rem;
  position:relative;
  max-height:88vh;
  overflow-y:auto;
}
.cookie-close{
  position:absolute;
  top:1.2rem; right:1.2rem;
  background:transparent;
  border:none;
  font-size:1.6rem;
  cursor:pointer;
  color:var(--color-ink-soft);
}
.cookie-option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 0;
  border-top:1px solid var(--color-border);
}
.cookie-option input{width:22px; height:22px;}
.cookie-actions{display:flex; flex-wrap:wrap; gap:0.8rem; margin-top:1.5rem;}
.cookie-actions button{flex:1; min-width:120px;}


@media (max-width: 1024px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-cards{height:auto; display:flex; flex-direction:column; gap:1.2rem; margin-top:2rem;}
  .hero-card{position:static; width:100%; transform:none !important;}
  .problem-grid{grid-template-columns:repeat(2, 1fr);}
  .steps-row{flex-direction:column;}
  .step-connector{display:none;}
  .image-grid{grid-template-columns:1fr;}
  .image-grid.reverse{direction:ltr;}
  .audience-grid{grid-template-columns:1fr;}
  .portrait-strip{grid-template-columns:1fr;}
  .format-grid{grid-template-columns:repeat(2, 1fr);}
  .terms-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .footer-links{grid-template-columns:repeat(3, 1fr);}
  .news-grid{grid-template-columns:1fr;}
}

@media (max-width: 768px){
  .nav-side.nav-left,.nav-side.nav-right{display:none;}
  .mobile-open-btn{display:flex;}
  .nav-full{justify-content:space-between;}
  .nav-side.nav-right{gap:0.8rem;}
  .nav-cta{display:none;}
  .problem-grid{grid-template-columns:1fr;}
  .format-grid{grid-template-columns:1fr;}
  .footer-links{grid-template-columns:1fr; gap:1.5rem;}
  .timeline-item{flex-direction:column;}
  .space-section{padding:var(--space-xl) 1.2rem;}
  .shift-item{flex-direction:column; gap:0.5rem;}
  .shift-num{width:auto;}
}

@media (max-width: 480px){
  .hero-title{font-size:2rem;}
  .cookie-link span{display:none;}
}