/* ContentLab — Kateryna Albul. Ported pixel-match from the Claude Design homepage. */

:root {
  --bg: #F4EEE3;
  --bg-alt: #ECE6DA;
  --bg-cases: #EFE8DB;
  --dark: #1C1A17;
  --darker: #161410;
  --surface: #FBF8F2;
  --surface-dark: #262320;
  --accent: #CB3B2B;
  --accent-press: #A62A1E;
  --accent-on-dark: #F0786A;
  --text: #211E1A;
  --text-2: #3C3830;
  --text-3: #544E45;
  --text-4: #8A8073;
  --text-soft: #6B6358;
  --text-on-dark: #C9BFB0;
  --text-on-dark-2: #A89E8E;
  --text-on-dark-3: #D9CFBF;
  --border: #E4DCCE;
  --border-2: #E9E1D2;
  --border-dark: #34302B;
  --tile-bg: #EDE4D4;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg-alt);
  font-family: 'Onest', sans-serif;
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
::selection { background: var(--accent); color: #fff; }
[id] { scroll-margin-top: 88px; }
a { color: inherit; }
img { display: block; }

.accent-italic { font-family: 'Cormorant', serif; font-style: italic; font-weight: 600; color: var(--accent); }
.services .accent-italic,
.niches .accent-italic,
.contact .accent-italic { color: var(--accent-on-dark); }

@keyframes clab-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes clab-sheen { 0% { transform: translateX(-120%) skewX(-18deg); } 60%,100% { transform: translateX(320%) skewX(-18deg); } }
@keyframes clab-floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes clab-modal { from { opacity: 0; transform: translateY(20px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes clab-fade { from { opacity: 0; } to { opacity: 1; } }

.page { background: var(--bg); overflow: hidden; }
.wrap { max-width: 1200px; margin: 0 auto; padding-left: clamp(20px, 5vw, 40px); padding-right: clamp(20px, 5vw, 40px); }
.eyebrow { font-weight: 600; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.eyebrow--dark { color: var(--accent-on-dark); }
.section-title { font-weight: 800; font-size: clamp(30px, 5.4vw, 46px); line-height: 1.05; letter-spacing: -0.03em; margin: 0; }

/* ============ HEADER ============ */
.header { position: sticky; top: 0; z-index: 80; background: rgba(244,238,227,0.82); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); }
.header__inner { max-width: 1200px; margin: 0 auto; padding: 14px clamp(18px,5vw,40px); display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.logo { text-decoration: none; color: inherit; font-weight: 800; font-size: 19px; letter-spacing: -0.02em; }
.logo .dot, .footer__brand .dot { color: var(--accent); }
.nav { display: flex; align-items: center; gap: 30px; }
.nav a { text-decoration: none; color: var(--text-3); font-size: 14.5px; font-weight: 500; transition: color 0.25s ease; }
.nav a:hover { color: var(--accent); }
.btn { text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 9px; border-radius: 100px; font-weight: 600; transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease, border-color 0.25s ease; }
.btn--primary { background: var(--accent); color: #fff; }
.btn--primary:hover { background: var(--accent-press); }
.nav .btn--primary { font-size: 14.5px; padding: 10px 22px; color: #fff; }
.btn--hero { font-size: 16px; padding: 15px 30px; }
.btn--hero.btn--primary:hover { transform: translateY(-2px); }
.btn--outline { color: var(--dark); font-size: 16px; padding: 14px 29px; border: 1.5px solid var(--dark); }
.btn--outline:hover { background: var(--dark); color: var(--bg); }

.burger { display: none; width: 44px; height: 44px; border: 1px solid var(--border); background: var(--surface); border-radius: 12px; cursor: pointer; align-items: center; justify-content: center; flex-direction: column; gap: 4px; padding: 0; }
.burger span { display: block; width: 18px; height: 2px; background: var(--dark); border-radius: 2px; }
.mobile-menu { border-top: 1px solid var(--border); background: var(--bg); padding: 12px clamp(20px,5vw,40px) 18px; display: none; flex-direction: column; gap: 2px; }
.mobile-menu.is-open { display: flex; }
.mobile-menu a { text-decoration: none; color: var(--text); font-size: 17px; font-weight: 600; padding: 13px 6px; border-bottom: 1px solid #ECE3D4; }
.mobile-menu a.btn--primary { font-size: 16px; padding: 14px; text-align: center; margin-top: 12px; border-bottom: none; border-radius: 100px; color: #fff; background: var(--accent); }

@media (max-width: 920px) {
  .nav { display: none !important; }
  .burger { display: flex !important; }
}
@media (min-width: 921px) {
  .mobile-menu { display: none !important; }
}

/* ============ HERO ============ */
.hero { max-width: 1200px; margin: 0 auto; padding: clamp(44px,7vw,76px) clamp(20px,5vw,40px) clamp(56px,8vw,88px); display: grid; grid-template-columns: repeat(auto-fit, minmax(330px,1fr)); gap: clamp(36px,5vw,60px); align-items: center; }
.hero__eyebrow { font-weight: 600; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); margin-bottom: 26px; }
.hero__title { font-weight: 800; font-size: clamp(38px,7vw,66px); line-height: 1.03; letter-spacing: -0.035em; margin: 0; }
.hero__sub { font-size: 20px; line-height: 1.55; color: var(--text-3); max-width: 520px; margin: 30px 0 0; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 38px; }
.hero__stats { display: flex; gap: 30px; margin-top: 46px; padding-top: 26px; border-top: 1px solid var(--border); }
.stat__value { font-weight: 800; font-size: 26px; letter-spacing: -0.02em; }
.stat__label { font-size: 13px; color: var(--text-4); margin-top: 2px; }
.hero__media { position: relative; }
.hero__frame { position: relative; aspect-ratio: 4/5; border-radius: 26px; overflow: hidden; background: var(--tile-bg); box-shadow: 0 30px 70px -30px rgba(28,26,23,0.4); }
.hero__frame img { width: 100%; height: 100%; object-fit: cover; }
.sheen-wrap { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.sheen { position: absolute; top: 0; left: 0; width: 40%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent); animation: clab-sheen 6.5s ease-in-out 1.2s infinite; }
.hero__badge { position: absolute; bottom: 24px; left: -22px; background: var(--surface); border: 1px solid var(--border-2); border-radius: 16px; padding: 14px 20px; box-shadow: 0 18px 40px -20px rgba(28,26,23,0.45); animation: clab-floaty 5s ease-in-out infinite; }
.hero__badge-title { font-family: 'Cormorant', serif; font-style: italic; font-size: 18px; color: var(--dark); }
.hero__badge-sub { font-size: 12.5px; color: var(--text-4); margin-top: 1px; }

/* ============ ABOUT ============ */
.about { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,80px) clamp(20px,5vw,40px); }
.about__title { font-weight: 800; font-size: clamp(30px,5.6vw,46px); line-height: 1.08; letter-spacing: -0.03em; margin: 0 0 clamp(36px,5vw,52px); max-width: 780px; }
.about__title .accent-italic { font-weight: 500; }
.about__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: clamp(40px,5vw,64px); align-items: start; }
.about__media { position: relative; }
.about__frame { aspect-ratio: 4/5; border-radius: 24px; overflow: hidden; background: var(--tile-bg); box-shadow: 0 34px 70px -34px rgba(28,26,23,0.5); }
.about__frame img { width: 100%; height: 100%; object-fit: cover; }
.about__chip { position: absolute; left: 18px; bottom: -20px; background: var(--dark); color: var(--bg); border-radius: 14px; padding: 14px 22px; box-shadow: 0 20px 44px -22px rgba(28,26,23,0.55); }
.about__chip-name { font-weight: 700; font-size: 16px; letter-spacing: -0.01em; }
.about__chip-sub { font-size: 12.5px; color: var(--text-on-dark-2); margin-top: 2px; }
.about__p { font-size: 18px; line-height: 1.6; margin: 0 0 16px; }
.about__p--1 { color: var(--text-2); }
.about__p--2 { color: var(--text-3); margin-bottom: 26px; }
.about__p mark { background: #F4DAD3; color: var(--accent-press); padding: 0 6px; border-radius: 4px; font-weight: 600; }
.about__quote { font-family: 'Cormorant', serif; font-style: italic; font-size: 25px; line-height: 1.36; color: var(--dark); margin: 0 0 40px; border-left: 2px solid var(--accent); padding-left: 22px; }
.about__pillars-title { font-weight: 600; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-4); margin-bottom: 6px; }
.pillar { display: grid; grid-template-columns: 48px 1fr; gap: 18px; align-items: baseline; padding: 20px 0; border-bottom: 1px solid var(--border); }
.pillar:last-child { border-bottom: none; }
.pillar__num { font-family: 'Cormorant', serif; font-style: italic; font-size: 26px; color: var(--accent); font-weight: 600; }
.pillar__lead { font-weight: 700; font-size: 17px; }
.pillar__text { font-size: 16px; color: var(--text-soft); }

/* ============ SERVICES ============ */
.services { background: var(--dark); color: var(--bg); }
.services__inner { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,84px) clamp(20px,5vw,40px); }
.services__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; margin-bottom: 44px; flex-wrap: wrap; }
.services__title { font-weight: 800; font-size: clamp(30px,5.4vw,46px); line-height: 1.05; letter-spacing: -0.03em; margin: 0; max-width: 560px; }
.services__title .accent-italic { font-weight: 500; }
.services__thumb { width: 120px; height: 150px; border-radius: 16px; overflow: hidden; flex-shrink: 0; }
.services__thumb img { width: 100%; height: 100%; object-fit: cover; }
.services__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px,1fr)); gap: 16px; }
.service-card { background: var(--surface-dark); border: 1px solid var(--border-dark); border-radius: 18px; padding: 26px; transition: transform 0.3s ease, border-color 0.3s ease; }
.service-card:hover { transform: translateY(-5px); border-color: #5A372F; }
.service-card__num { font-family: 'Cormorant', serif; font-style: italic; font-size: 20px; color: var(--accent-on-dark); font-weight: 600; margin-bottom: 14px; }
.service-card__title { font-weight: 700; font-size: 18px; margin-bottom: 8px; }
.service-card__text { font-size: 14px; color: var(--text-on-dark-2); line-height: 1.5; }
.services__note { display: flex; flex-wrap: wrap; gap: 16px 30px; align-items: center; justify-content: space-between; margin-top: 24px; background: var(--surface-dark); border: 1px solid var(--border-dark); border-radius: 18px; padding: 22px 28px; }
.services__note-addons { font-size: 14.5px; color: #C9BFB0; }
.services__note-official { font-size: 14.5px; color: var(--bg); font-weight: 600; display: inline-flex; align-items: center; gap: 10px; }
.services__note-official .dot { width: 7px; height: 7px; border-radius: 100px; background: var(--accent-on-dark); display: inline-block; }

/* ============ PRICING ============ */
.pricing { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,84px) clamp(20px,5vw,40px); }
.pricing__title { margin: 0 0 clamp(36px,5vw,52px); max-width: 640px; }
.pricing__title .accent-italic { font-weight: 500; }
.pricing__layout { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: clamp(32px,4vw,48px); align-items: start; }
.pricing__card { background: var(--surface); border: 1px solid var(--border-2); border-radius: 26px; padding: clamp(32px,4vw,48px); box-shadow: 0 18px 50px -24px rgba(28,26,23,0.12); }
.pricing__card-label { font-weight: 600; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }
.pricing__card-price { font-family: 'Cormorant', serif; font-style: italic; font-weight: 600; font-size: clamp(38px,6vw,56px); line-height: 1.05; letter-spacing: -0.02em; color: var(--dark); margin-bottom: 32px; }
.pricing__includes { list-style: none; margin: 0 0 36px; padding: 0; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--border); }
.pricing__includes-item { display: flex; align-items: baseline; gap: 13px; padding: 14px 0; border-bottom: 1px solid var(--border); font-size: 16px; color: var(--text-2); }
.pricing__check { color: var(--accent); font-weight: 800; font-size: 14px; flex-shrink: 0; }
.pricing__cta { font-size: 16px; padding: 15px 32px; width: 100%; justify-content: center; }
.pricing__note-wrap { display: flex; align-items: flex-start; padding-top: 8px; }
.pricing__note { font-size: 17px; line-height: 1.65; color: var(--text-3); margin: 0; }

/* ============ APPROACH ============ */
.approach { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,84px) clamp(20px,5vw,40px); }
.approach__title { margin: 0 0 44px; max-width: 640px; }
.approach__title .accent-italic { font-weight: 500; }
.approach__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: clamp(32px,4vw,48px); align-items: start; }
.approach__list { display: flex; flex-direction: column; gap: 14px; }
.approach-card { background: var(--surface); border: 1px solid var(--border-2); border-radius: 18px; padding: 28px 30px; }
.approach-card__row { display: flex; gap: 18px; align-items: baseline; }
.approach-card__num { font-family: 'Cormorant', serif; font-style: italic; font-size: 24px; color: var(--accent); font-weight: 600; flex-shrink: 0; }
.approach-card__title { font-weight: 700; font-size: 19px; margin-bottom: 7px; }
.approach-card__text { font-size: 15px; color: var(--text-3); line-height: 1.55; }
.approach__gallery { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.approach__gallery-tile { aspect-ratio: 3/4; border-radius: 16px; overflow: hidden; background: var(--tile-bg); }
.approach__gallery-tile:nth-child(even) { margin-top: 26px; }
.approach__gallery-tile img { width: 100%; height: 100%; object-fit: cover; }

/* ============ CASES ============ */
.cases { background: var(--bg-cases); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.cases__inner { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,84px) clamp(20px,5vw,40px); }
.cases__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; margin-bottom: 44px; flex-wrap: wrap; }
.cases__note { font-size: 15px; color: var(--text-soft); max-width: 360px; line-height: 1.5; }
.cases__featured { display: grid; grid-template-columns: repeat(auto-fit, minmax(330px,1fr)); gap: 18px; margin-bottom: 18px; }
.featured-card { position: relative; border-radius: 22px; overflow: hidden; min-height: 400px; display: flex; flex-direction: column; justify-content: flex-end; color: var(--bg); background: var(--dark); text-decoration: none; transition: transform 0.35s ease, box-shadow 0.35s ease; }
.featured-card:hover { transform: translateY(-6px); box-shadow: 0 30px 60px -30px rgba(28,26,23,0.55); }
.featured-card > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.featured-card__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,18,16,0.12) 28%, rgba(20,18,16,0.93)); }
.featured-card__body { position: relative; padding: clamp(28px,4vw,42px); }
.featured-card__tag { font-weight: 600; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-on-dark); }
.featured-card__title { font-weight: 800; font-size: clamp(28px,4vw,36px); letter-spacing: -0.02em; margin: 14px 0 6px; line-height: 1.05; }
.featured-card__niche { font-size: 15px; color: var(--text-on-dark); margin-bottom: 18px; }
.featured-card__more { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 15px; color: var(--accent-on-dark); }
.featured-card__more span { font-size: 18px; }

.cases__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 18px; grid-auto-rows: 1fr; }
.case-card { background: var(--surface); border: 1px solid var(--border-2); border-radius: 18px; overflow: hidden; height: 100%; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: transform 0.32s ease, box-shadow 0.32s ease; }
.case-card:hover { transform: translateY(-6px); box-shadow: 0 24px 46px -26px rgba(28,26,23,0.45); }
.case-card__media { aspect-ratio: 4/5; overflow: hidden; background: var(--tile-bg); flex-shrink: 0; }
.case-card__media img { width: 100%; height: 100%; object-fit: cover; }
.case-card__body { padding: 18px 20px; flex: 1; display: flex; flex-direction: column; }
.case-card__tag { font-weight: 600; font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.case-card__title { font-weight: 700; font-size: 17px; margin: 6px 0 3px; }
.case-card__short { font-size: 13px; color: var(--text-4); line-height: 1.4; }
.case-card__more { margin-top: auto; padding-top: 14px; font-size: 12.5px; font-weight: 600; color: var(--accent); display: flex; align-items: center; gap: 6px; }
.case-card__more span { font-size: 15px; line-height: 0; }

/* ============ MODAL ============ */
.modal { position: fixed; inset: 0; z-index: 200; background: rgba(20,18,16,0.64); backdrop-filter: blur(6px); display: none; align-items: center; justify-content: center; padding: 32px; }
.modal.is-open { display: flex; animation: clab-fade 0.25s ease; }
.modal__panel { position: relative; background: var(--bg); border-radius: 26px; max-width: 960px; width: 100%; max-height: 88vh; overflow: auto; box-shadow: 0 50px 110px -40px rgba(0,0,0,0.65); animation: clab-modal 0.34s cubic-bezier(0.22,1,0.36,1); }
.modal__close { position: absolute; top: 18px; right: 18px; z-index: 3; width: 42px; height: 42px; border-radius: 100px; border: none; background: var(--dark); color: var(--bg); font-size: 17px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s ease; }
.modal__close:hover { background: var(--accent); }
.modal__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 0; }
.modal__media { position: relative; background: var(--tile-bg); min-height: 440px; }
.modal__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.modal__content { padding: 48px 46px 36px; }
.modal__tag { font-weight: 600; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.modal__title { font-weight: 800; font-size: 32px; letter-spacing: -0.02em; margin: 14px 0 6px; line-height: 1.04; }
.modal__niche { font-size: 14.5px; color: var(--text-4); margin-bottom: 22px; }
.modal__result { font-size: 16px; line-height: 1.55; color: var(--text-2); margin: 0 0 20px; }
.modal__point { display: flex; gap: 13px; align-items: baseline; padding: 11px 0; border-top: 1px solid var(--border); }
.modal__point-dot { color: var(--accent); font-weight: 800; font-size: 16px; line-height: 1; }
.modal__point-text { font-size: 14.5px; color: var(--text-2); line-height: 1.45; }
.modal__cta { text-decoration: none; display: inline-flex; align-items: center; gap: 9px; margin-top: 26px; background: var(--accent); color: #fff; font-weight: 600; font-size: 15px; padding: 13px 26px; border-radius: 100px; transition: background 0.25s ease; }
.modal__cta:hover { background: var(--accent-press); }
.modal__gallery-wrap { padding: 4px 46px 42px; }
.modal__gallery-title { font-weight: 600; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); margin: 14px 0 14px; }
.modal__gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px,1fr)); gap: 12px; }
.modal__gallery-tile { aspect-ratio: 4/5; border-radius: 12px; overflow: hidden; background: var(--tile-bg); }
.modal__gallery-tile img { width: 100%; height: 100%; object-fit: cover; }
.modal__gallery-ph { aspect-ratio: 4/5; border-radius: 12px; border: 1px dashed #D8C7C2; background: var(--surface); display: flex; align-items: center; justify-content: center; text-align: center; padding: 14px; }
.modal__gallery-ph span { color: #B0A696; font-family: 'Cormorant', serif; font-style: italic; font-size: 15px; }
.modal__gallery-foot { font-size: 13px; color: #9A9082; margin-top: 14px; }

@media (max-width: 560px) {
  .modal__grid { grid-template-columns: 1fr; }
}

/* ============ NICHES ============ */
.niches { background: var(--dark); color: var(--bg); padding: 54px 0; overflow: hidden; }
.niches__head { max-width: 1200px; margin: 0 auto 30px; padding: 0 40px; display: flex; justify-content: space-between; align-items: baseline; gap: 20px; flex-wrap: wrap; }
.niches__count { font-size: 15px; color: var(--text-on-dark-2); }
.niches__track { display: flex; gap: 14px; width: max-content; animation: clab-marquee 38s linear infinite; }
.niches__track:hover { animation-play-state: paused; }
.niche-pill { text-decoration: none; color: var(--text-on-dark-3); border: 1px solid var(--border-dark); border-radius: 100px; padding: 11px 22px; font-size: 15px; font-weight: 500; white-space: nowrap; transition: border-color 0.25s, color 0.25s; }
a.niche-pill:hover { border-color: var(--accent-on-dark); color: var(--bg); }
.niche-pill--highlight { color: var(--dark); background: var(--accent-on-dark); border-color: var(--accent-on-dark); font-weight: 600; }

/* ============ REVIEWS ============ */
.reviews { max-width: 1200px; margin: 0 auto; padding: clamp(56px,8vw,84px) clamp(20px,5vw,40px); }
.reviews__title { margin: 0 0 40px; }
.reviews__title .accent-italic { font-weight: 500; }
.reviews__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 18px; margin-bottom: 34px; }
.review-ph { background: var(--surface); border: 1px dashed #D8C7C2; border-radius: 18px; padding: 30px; }
.review-ph__quote { font-family: 'Cormorant', serif; font-style: italic; font-size: 40px; color: #E0C9C3; line-height: 0.5; }
.review-ph__lines { margin-top: 18px; }
.review-ph__line { height: 12px; background: var(--tile-bg); border-radius: 5px; margin-bottom: 10px; }
.review-ph__line:last-child { margin-bottom: 0; }
.review-ph__line--a { width: 90%; } .review-ph__line--b { width: 78%; } .review-ph__line--c { width: 55%; }
.review-ph__author { display: flex; align-items: center; gap: 12px; margin-top: 24px; }
.review-ph__avatar { width: 42px; height: 42px; border-radius: 100px; background: var(--tile-bg); border: 1px dashed #D8CFBE; }
.review-ph__name { height: 10px; width: 90px; background: var(--tile-bg); border-radius: 4px; margin-bottom: 6px; }
.review-ph__role { height: 9px; width: 60px; background: #F0E7D8; border-radius: 4px; }
.reviews__ratings { background: var(--dark); border-radius: 18px; padding: 26px 30px; display: flex; flex-wrap: wrap; gap: 18px 40px; align-items: center; }
.reviews__ratings-note { font-size: 13px; color: var(--text-on-dark-2); max-width: 300px; line-height: 1.45; }
.reviews__ratings-grid { display: flex; flex-wrap: wrap; gap: 30px; }
.rating__value { font-weight: 800; font-size: 24px; color: var(--bg); }
.rating__value .star { font-size: 14px; color: var(--accent-on-dark); }
.rating__label { font-size: 12.5px; color: var(--text-4); margin-top: 2px; }

/* ============ CONTACT ============ */
.contact { max-width: 1200px; margin: 0 auto; padding: clamp(20px,5vw,40px) clamp(20px,5vw,40px) clamp(60px,8vw,90px); }
.contact__card { background: var(--dark); border-radius: 30px; overflow: hidden; display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); color: var(--bg); }
.contact__body { padding: clamp(40px,6vw,64px) clamp(28px,5vw,60px); display: flex; flex-direction: column; justify-content: center; }
.contact__title { font-weight: 800; font-size: clamp(32px,6vw,48px); line-height: 1.05; letter-spacing: -0.03em; margin: 0 0 18px; }
.contact__title .accent-italic { font-weight: 500; }
.contact__text { font-size: 18px; color: var(--text-on-dark); line-height: 1.55; margin: 0 0 36px; max-width: 420px; }
.contact__channels { display: flex; flex-direction: column; gap: 12px; max-width: 380px; }
.contact__channel { text-decoration: none; display: flex; align-items: center; justify-content: space-between; background: var(--surface-dark); border: 1px solid var(--border-dark); border-radius: 14px; padding: 16px 22px; color: var(--bg); transition: background 0.25s, border-color 0.25s; }
.contact__channel:hover { background: #2F2A25; border-color: var(--accent-on-dark); }
.contact__channel-label { display: flex; flex-direction: column; }
.contact__channel-kind { font-size: 12px; color: var(--text-4); }
.contact__channel-val { font-weight: 600; font-size: 16px; }
.contact__channel-arrow { color: var(--accent-on-dark); font-size: 18px; }
.contact__media { position: relative; background: var(--tile-bg); min-height: 420px; }
.contact__media img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.contact__media-overlay { position: absolute; inset: 0; background: linear-gradient(120deg, rgba(28,26,23,0.45), rgba(28,26,23,0.04)); }

/* ============ FOOTER ============ */
.footer { background: var(--darker); color: var(--bg); border-top: 1px solid #2A2620; }
.footer__inner { max-width: 1200px; margin: 0 auto; padding: 56px 40px 40px; }
.footer__top { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; padding-bottom: 34px; border-bottom: 1px solid #2A2620; }
.footer__about { max-width: 320px; }
.footer__brand { font-weight: 800; font-size: 22px; letter-spacing: -0.02em; margin-bottom: 14px; }
.footer__tagline { font-size: 14.5px; color: var(--text-4); line-height: 1.55; margin: 0 0 16px; }
.footer__ig { text-decoration: none; color: var(--accent-on-dark); font-weight: 600; font-size: 14.5px; }
.footer__cols { display: flex; gap: 60px; flex-wrap: wrap; }
.footer__col-title { font-weight: 600; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-soft); margin-bottom: 16px; }
.footer__links { display: flex; flex-direction: column; gap: 11px; }
.footer__links a { text-decoration: none; color: var(--text-on-dark); font-size: 14.5px; transition: color 0.25s; }
.footer__links a:hover { color: var(--bg); }
.footer__bottom { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; padding-top: 24px; font-size: 13px; color: var(--text-soft); }

/* ============ REVEAL ============ */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1); }
[data-reveal].is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  .sheen, .hero__badge, .niches__track { animation: none; }
}

/* ============ CASE DETAIL PAGE ============ */
.case-page { max-width: 880px; margin: 0 auto; padding: clamp(40px,7vw,80px) clamp(20px,5vw,40px) clamp(60px,8vw,90px); }
.case-page__back { text-decoration: none; color: var(--accent); font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 7px; margin-bottom: 30px; }
.case-page__tag { font-weight: 600; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.case-page__title { font-weight: 800; font-size: clamp(32px,6vw,52px); letter-spacing: -0.03em; line-height: 1.04; margin: 14px 0 8px; }
.case-page__niche { font-size: 16px; color: var(--text-4); margin-bottom: 32px; }
.case-page__cover { border-radius: 22px; overflow: hidden; background: var(--tile-bg); margin-bottom: 36px; box-shadow: 0 30px 70px -34px rgba(28,26,23,0.45); }
.case-page__cover img { width: 100%; height: auto; }
.case-page__result { font-size: 19px; line-height: 1.6; color: var(--text-2); margin: 0 0 28px; }
.case-page__points { list-style: none; padding: 0; margin: 0 0 36px; }
.case-page__points li { display: flex; gap: 13px; align-items: baseline; padding: 14px 0; border-top: 1px solid var(--border); font-size: 16px; color: var(--text-2); line-height: 1.5; }
.case-page__points li::before { content: "·"; color: var(--accent); font-weight: 800; font-size: 18px; }
.case-page__body { font-size: 17px; line-height: 1.65; color: var(--text-3); margin-bottom: 36px; }
.case-page__gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 12px; margin-bottom: 40px; }
.case-page__gallery-tile { aspect-ratio: 4/5; border-radius: 12px; overflow: hidden; background: var(--tile-bg); }
.case-page__gallery-tile img { width: 100%; height: 100%; object-fit: cover; }
.case-page__gallery-tile--placeholder { border: 1px dashed #D8C7C2; background: var(--surface); display: flex; align-items: center; justify-content: center; }
.case-page__gallery-tile--placeholder span { color: #B0A696; font-family: 'Cormorant', serif; font-style: italic; font-size: 15px; }
