/* ============================================================
   DANIMAK Limited — DARK PREMIUM Edition
   Deep violet-black · glass · glow · large Fraunces serif
   Same markup/classes as the light theme (shares js/main.js)
   ============================================================ */

:root {
  --bg: #0b0610;
  --bg-2: #120a1b;
  --bg-3: #170d24;
  --ink: #f4eefb;
  --ink-soft: rgba(244, 238, 251, 0.62);
  --ink-faint: rgba(244, 238, 251, 0.34);
  --line: rgba(199, 125, 255, 0.14);
  --line-2: rgba(199, 125, 255, 0.22);

  --violet: #b06bf0;
  --violet-bright: #c77dff;
  --violet-deep: #7b2cbf;
  --violet-soft: #c99cf0;

  --glass: rgba(255, 255, 255, 0.035);
  --glass-line: rgba(199, 125, 255, 0.16);

  --glow: 0 0 80px -10px rgba(157, 78, 221, 0.55);
  --grad-text: linear-gradient(110deg, #c77dff 0%, #e0aaff 60%, #b06bf0 100%);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans: "Manrope", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --container: 1280px;
  --pad: clamp(1.5rem, 5vw, 5rem);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans); background: var(--bg); color: var(--ink);
  line-height: 1.6; overflow-x: hidden; -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility; position: relative;
}
/* premium grain + ambient top glow */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 40% at 80% -5%, rgba(123, 44, 191, 0.28), transparent 60%),
    radial-gradient(50% 35% at 10% 5%, rgba(157, 78, 221, 0.18), transparent 60%);
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: 9997; pointer-events: none; opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
em { font-style: italic; }
address { font-style: normal; }
svg { display: block; }

.container { width: min(100% - 2 * var(--pad), var(--container)); margin-inline: auto; position: relative; z-index: 1; }
.section { padding-block: clamp(5rem, 11vw, 11rem); position: relative; z-index: 1; }

.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 2rem; }
.col-aside { grid-column: 1 / 4; }
.col-main { grid-column: 4 / 12; }

/* Kicker */
.kicker { font-size: .8rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); display: flex; align-items: baseline; gap: .8rem; padding-top: .6rem; }
.kicker .idx { font-family: var(--serif); font-style: italic; font-size: 1.4rem; color: var(--violet-bright); font-weight: 400; }
.kicker--light { color: var(--ink-soft); }
.kicker--light .idx { color: var(--violet-bright); }

/* Display headings */
.display { font-family: var(--serif); font-weight: 340; font-size: clamp(2rem, 4.6vw, 3.9rem); line-height: 1.07; letter-spacing: -0.015em; color: var(--ink); }
.display em, .display--light em { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.display--light { color: var(--ink); }
.section-head { margin-bottom: clamp(3rem, 6vw, 5.5rem); }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader { position: fixed; inset: 0; z-index: 9999; background: var(--bg); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2rem; }
.preloader__word { display: flex; font-family: var(--serif); font-weight: 300; font-size: clamp(2.5rem, 9vw, 6rem); letter-spacing: .04em; color: var(--ink); }
.preloader__word span { opacity: 0; transform: translateY(60%); }
.preloader__bar { width: min(220px, 50vw); height: 1px; background: var(--line); overflow: hidden; }
.preloader__bar i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--violet-deep), var(--violet-bright)); box-shadow: 0 0 12px rgba(199,125,255,.8); }

/* ============================================================
   HEADER
   ============================================================ */
.header { position: fixed; top: 0; left: 0; width: 100%; z-index: 900; display: flex; align-items: center; justify-content: space-between; padding: 1.6rem var(--pad); transition: padding .5s var(--ease), background .5s var(--ease), border-color .5s; border-bottom: 1px solid transparent; }
.header.is-scrolled { background: rgba(11, 6, 16, 0.72); backdrop-filter: blur(18px); padding-block: 1rem; border-bottom-color: var(--line); }

.brand { display: flex; align-items: center; gap: .7rem; }
.brand__mark { width: 34px; height: auto; transition: transform .5s var(--ease); filter: drop-shadow(0 0 10px rgba(157,78,221,.5)); }
.brand:hover .brand__mark { transform: rotate(-6deg) scale(1.08); }
.brand__text { font-family: var(--serif); font-weight: 500; font-size: 1.25rem; color: var(--ink); }
.brand__text em { font-style: italic; color: var(--violet-bright); font-weight: 400; }

.nav__list { display: flex; gap: 2rem; }
.nav__list a { font-size: .82rem; font-weight: 500; letter-spacing: .04em; color: var(--ink-soft); display: inline-flex; align-items: baseline; gap: .4rem; position: relative; padding: .3rem 0; transition: color .35s; }
.nav__list a span { font-family: var(--serif); font-style: italic; font-size: .72rem; color: var(--violet-bright); }
.nav__list a::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 0; height: 1px; background: var(--violet-bright); transition: width .4s var(--ease); }
.nav__list a:hover { color: var(--ink); }
.nav__list a:hover::after, .nav__list a.is-active::after { width: 100%; }

.link-cta { font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--ink); display: inline-flex; align-items: center; gap: .5rem; transition: gap .35s var(--ease), color .35s; }
.link-cta i { color: var(--violet-bright); transition: transform .35s var(--ease); }
.link-cta:hover { color: var(--violet-bright); }
.link-cta:hover i { transform: translateX(5px); }

.burger { display: none; width: 40px; height: 40px; position: relative; z-index: 950; }
.burger span { position: absolute; left: 8px; width: 24px; height: 1.5px; background: var(--ink); transition: transform .4s var(--ease); }
.burger span:nth-child(1) { top: 16px; }
.burger span:nth-child(2) { top: 23px; }
.menu-open .burger span:nth-child(1) { transform: translateY(3.5px) rotate(45deg); }
.menu-open .burger span:nth-child(2) { transform: translateY(-3.5px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height: 100vh; padding: 8rem var(--pad) 4rem; display: flex; flex-direction: column; justify-content: center;
  position: relative; overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: linear-gradient(rgba(199,125,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(199,125,255,.05) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 45%, #000 25%, transparent 78%);
}
.hero::after {
  content: ""; position: absolute; width: 60vw; height: 60vw; max-width: 760px; max-height: 760px;
  right: -14vw; top: 6%; border-radius: 50%; z-index: 0; pointer-events: none;
  background: radial-gradient(circle, rgba(157,78,221,.42), transparent 65%); filter: blur(50px);
  animation: floaty 16s ease-in-out infinite;
}
@keyframes floaty { 0%,100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-46px) scale(1.08); } }
.hero > * { position: relative; z-index: 2; }

.hero__meta { display: flex; gap: 2rem; flex-wrap: wrap; margin-bottom: clamp(1.5rem, 4vw, 3rem); width: min(100%, var(--container)); margin-inline: auto; }
.hero__meta .r { font-size: .76rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); position: relative; padding-left: 1.2rem; }
.hero__meta .r::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 6px; height: 6px; border-radius: 50%; background: var(--violet-bright); box-shadow: 0 0 10px var(--violet-bright); }

.hero__title { font-family: var(--serif); font-weight: 330; letter-spacing: -0.02em; font-size: clamp(2.8rem, 9.5vw, 9rem); line-height: 0.98; color: var(--ink); width: min(100%, var(--container)); margin-inline: auto; }
.hero__title .l { display: block; overflow: hidden; padding-bottom: .08em; }
.hero__title .l > span { display: block; }
.hero__title em { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }

.hero__foot { display: flex; justify-content: space-between; align-items: flex-end; gap: 3rem; flex-wrap: wrap; margin-top: clamp(2.5rem, 6vw, 4.5rem); width: min(100%, var(--container)); margin-inline: auto; }
.hero__lead { max-width: 38ch; font-size: clamp(1rem, 1.4vw, 1.18rem); color: var(--ink-soft); }

.hero__scroll { position: absolute; bottom: 2rem; right: var(--pad); display: flex; flex-direction: column; align-items: center; gap: .8rem; font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-faint); z-index: 2; }
.hero__scroll i { width: 1px; height: 48px; background: var(--line); position: relative; overflow: hidden; }
.hero__scroll i::after { content: ""; position: absolute; inset: 0 auto auto 0; width: 100%; height: 40%; background: var(--violet-bright); animation: drop 1.9s var(--ease) infinite; }
@keyframes drop { 0% { transform: translateY(-100%); } 100% { transform: translateY(250%); } }

/* Buttons */
.btn-line { font-family: var(--serif); font-style: italic; font-size: 1.1rem; color: var(--ink); display: inline-flex; align-items: center; gap: .6rem; padding-bottom: .35rem; border-bottom: 1px solid var(--ink); transition: gap .4s var(--ease), color .4s, border-color .4s; white-space: nowrap; }
.btn-line i { color: var(--violet-bright); transition: transform .4s var(--ease); }
.btn-line:hover { color: var(--violet-bright); border-color: var(--violet-bright); }
.btn-line:hover i { transform: translateX(6px); }
.btn-line--solid { border: 1px solid var(--line-2); border-radius: 100px; padding: .9rem 1.8rem; color: var(--violet-bright); font-size: 1rem; margin-top: .5rem; background: var(--glass); transition: background .4s, box-shadow .4s, color .4s, border-color .4s; }
.btn-line--solid:hover { background: linear-gradient(110deg, var(--violet-deep), var(--violet)); color: #fff; border-color: transparent; box-shadow: var(--glow); }
.btn-line--solid:hover i { color: #fff; }

/* ============================================================
   TICKER
   ============================================================ */
.ticker { border-block: 1px solid var(--line); padding: 1.4rem 0; overflow: hidden; white-space: nowrap; background: var(--bg-2); }
.ticker__track { display: inline-flex; align-items: center; gap: 2rem; animation: ticker 38s linear infinite; }
.ticker__track span { font-family: var(--serif); font-style: italic; font-size: clamp(1.3rem, 3vw, 2.1rem); color: var(--ink); font-weight: 300; }
.ticker__track b { color: var(--violet-bright); font-size: 1rem; }
@keyframes ticker { to { transform: translateX(-50%); } }

/* ============================================================
   INTRO / ABOUT
   ============================================================ */
.intro { background: var(--bg); }
.intro__statement { font-family: var(--serif); font-weight: 330; font-size: clamp(1.6rem, 3.4vw, 3rem); line-height: 1.18; letter-spacing: -0.01em; color: var(--ink); margin-bottom: 2rem; }
.intro__statement em { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.intro__body { max-width: 54ch; color: var(--ink-soft); font-size: 1.08rem; }

.values { margin-top: clamp(4rem, 8vw, 7rem); display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.value { padding: 2.5rem 1.8rem 2.5rem 0; border-right: 1px solid var(--line); transition: background .5s var(--ease); }
.value:last-child { border-right: none; padding-right: 0; }
.value:hover { background: var(--glass); }
.value__no { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--violet-bright); }
.value h3 { font-family: var(--serif); font-weight: 420; font-size: 1.4rem; margin: 1rem 0 .7rem; letter-spacing: -0.01em; }
.value p { color: var(--ink-soft); font-size: .96rem; }

/* ============================================================
   SERVICES
   ============================================================ */
.services { background: var(--bg); }
.svc-list { border-top: 1px solid var(--line); }
.svc { display: grid; grid-template-columns: 5rem 1fr 1.3fr; align-items: center; gap: 1.5rem; padding: clamp(1.4rem, 2.6vw, 2.2rem) 0; border-bottom: 1px solid var(--line); position: relative; transition: padding-left .5s var(--ease); }
.svc::before { content: ""; position: absolute; left: 0; top: 0; height: 100%; width: 0; background: linear-gradient(90deg, rgba(157,78,221,.12), transparent); z-index: -1; transition: width .5s var(--ease); }
.svc:hover { padding-left: 1.8rem; }
.svc:hover::before { width: calc(100% + 3.6rem); margin-left: -1.8rem; }
.svc__no { font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--violet-bright); }
.svc h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(1.2rem, 2.4vw, 1.9rem); letter-spacing: -0.01em; line-height: 1.15; transition: color .4s; }
.svc:hover h3 { color: var(--violet-bright); }
.svc p { color: var(--ink-soft); font-size: .98rem; }
@media (max-width: 760px) { .svc { grid-template-columns: 3rem 1fr; } .svc p { display: none; } }

/* ============================================================
   SOLUTIONS  (deepest band + glow)
   ============================================================ */
.solutions { background: var(--bg-3); position: relative; overflow: hidden; }
.solutions::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(50% 50% at 90% 0%, rgba(157,78,221,.3), transparent 65%), radial-gradient(45% 45% at 0% 100%, rgba(123,44,191,.24), transparent 65%); }
.solutions .container { position: relative; z-index: 2; }
.solutions__sub { margin-top: 1.2rem; color: var(--ink-soft); max-width: 44ch; font-size: 1.05rem; }
.steps { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.step { padding: clamp(2rem, 4vw, 3.2rem) 1.6rem clamp(2rem,4vw,3.2rem) 0; border-right: 1px solid var(--line); position: relative; transition: background .5s var(--ease); }
.step:last-child { border-right: none; padding-right: 0; }
.step:hover { background: var(--glass); }
.step__no { font-family: var(--serif); font-style: italic; font-size: 2.4rem; font-weight: 300; color: var(--violet-bright); display: block; margin-bottom: 1.2rem; }
.step h3 { font-family: var(--serif); font-weight: 400; font-size: 1.8rem; margin-bottom: .8rem; letter-spacing: -0.01em; }
.step p { color: var(--ink-soft); font-size: .98rem; }

/* ============================================================
   ACCREDITATIONS
   ============================================================ */
.partners { background: var(--bg); }
.logos { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.logo { display: grid; place-items: center; text-align: center; min-height: 150px; padding: 1.5rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); font-family: var(--serif); font-weight: 400; font-size: 1.15rem; color: var(--ink-faint); transition: color .45s, background .45s; }
.logo:hover { color: var(--violet-bright); background: var(--glass); }
@media (max-width: 900px) { .logos { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 520px) { .logos { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { background: var(--bg); }
.contact__sub { margin-top: 1.2rem; color: var(--ink-soft); max-width: 44ch; font-size: 1.05rem; }
.contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.offices { display: grid; }
.office { padding: 2rem 0; border-top: 1px solid var(--line); }
.office:last-child { border-bottom: 1px solid var(--line); }
.office h3 { font-size: .76rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--violet-bright); margin-bottom: 1rem; }
.office address { font-family: var(--serif); font-size: 1.25rem; font-weight: 360; line-height: 1.4; color: var(--ink); margin-bottom: 1rem; }
.office .muted { color: var(--ink-faint); }
.office ul { display: grid; gap: .35rem; }
.office li, .office a { font-size: .98rem; color: var(--ink-soft); transition: color .3s; }
.office a:hover { color: var(--violet-bright); }

.form { background: var(--glass); border: 1px solid var(--glass-line); border-radius: 20px; padding: clamp(1.8rem, 3.5vw, 3rem); backdrop-filter: blur(8px); box-shadow: var(--glow); }
.field { position: relative; margin-bottom: 1.6rem; border-bottom: 1px solid var(--line-2); }
.field input, .field textarea { width: 100%; padding: 1.6rem 0 .6rem; background: transparent; border: none; color: var(--ink); font-family: var(--sans); font-size: 1.05rem; resize: vertical; }
.field input:focus, .field textarea:focus { outline: none; }
.field label { position: absolute; left: 0; top: 1.4rem; color: var(--ink-soft); font-size: 1.05rem; pointer-events: none; transition: all .3s var(--ease); }
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label { top: 0; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--violet-bright); }
.field::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 0; height: 1px; background: var(--violet-bright); transition: width .4s var(--ease); }
.field:focus-within::after { width: 100%; }
.form-note { margin-top: 1rem; font-size: .92rem; color: var(--violet-bright); min-height: 1.2em; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--bg-2); color: var(--ink-soft); padding-block: clamp(4rem, 8vw, 6rem) 2.5rem; border-top: 1px solid var(--line); }
.footer__top { display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem; flex-wrap: wrap; padding-bottom: clamp(3rem, 6vw, 5rem); border-bottom: 1px solid var(--line); }
.footer__big { font-family: var(--serif); font-weight: 320; font-size: clamp(2.2rem, 6vw, 5rem); line-height: 1; letter-spacing: -0.02em; color: var(--ink); }
.footer__big em { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.footer .btn-line { color: var(--ink); border-color: var(--line-2); }
.footer .btn-line:hover { color: var(--violet-bright); border-color: var(--violet-bright); }
.footer .btn-line i { color: var(--violet-bright); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; gap: 1.5rem; flex-wrap: wrap; padding-top: 2.5rem; }
.brand--footer .brand__text { color: var(--ink); }
.brand--footer .brand__text em { color: var(--violet-bright); }
.footer__bottom p { font-size: .85rem; color: var(--ink-faint); }
.theme-switch { font-family: var(--serif); font-style: italic; font-size: 1rem; color: var(--violet-bright); display: inline-flex; align-items: center; gap: .4rem; transition: gap .35s var(--ease); }
.theme-switch:hover { gap: .7rem; color: var(--ink); }

/* ============================================================
   IMAGERY
   ============================================================ */
/* Hero faint architectural backdrop */
.hero__photo {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: url("../assets/img/design.jpg") center / cover no-repeat;
  opacity: .16;
  -webkit-mask-image: linear-gradient(to left, #000 0%, transparent 62%);
  mask-image: linear-gradient(to left, #000 0%, transparent 62%);
}

/* About feature image */
.feature { position: relative; margin-top: clamp(3rem, 6vw, 5rem); border-radius: 20px; overflow: hidden; border: 1px solid var(--line); }
.feature img { width: 100%; height: clamp(280px, 46vw, 560px); object-fit: cover; display: block; filter: brightness(.78) saturate(1.05); transition: transform 1.3s var(--ease); }
.feature:hover img { transform: scale(1.04); }
.feature::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,6,16,.9), transparent 58%), linear-gradient(120deg, rgba(123,44,191,.28), transparent 52%); }
.feature figcaption { position: absolute; left: clamp(1.5rem, 4vw, 3rem); bottom: clamp(1.5rem, 4vw, 3rem); z-index: 2; font-family: var(--serif); font-weight: 360; font-size: clamp(1.15rem, 2.4vw, 1.9rem); color: #fff; max-width: 22ch; line-height: 1.3; }
.feature figcaption span { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Solution steps → image cards */
.steps { gap: 1.4rem; border-top: none; }
.steps .step { padding: 0 !important; border: 1px solid var(--line) !important; border-radius: 16px; overflow: hidden; background: var(--glass); display: flex; flex-direction: column; transition: transform .5s var(--ease), border-color .5s, background .5s; }
.steps .step:hover { transform: translateY(-6px); border-color: var(--line-2) !important; background: rgba(157,78,221,.08); }
.step__media { overflow: hidden; aspect-ratio: 16 / 11; }
.step__media img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.82) saturate(1.05); transition: transform .9s var(--ease); }
.steps .step:hover .step__media img { transform: scale(1.07); }
.steps .step .step__no { margin: 1.3rem 1.4rem 0; font-size: 1.9rem; }
.steps .step h3 { margin: .4rem 1.4rem .5rem; }
.steps .step p { margin: 0 1.4rem 1.5rem; }

/* Cinematic showcase band */
.showcase { position: relative; min-height: 72vh; display: flex; align-items: flex-end; overflow: hidden; }
.showcase__media { position: absolute; inset: 0; z-index: 0; }
.showcase__media img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.showcase::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, var(--bg) 1%, rgba(11,6,16,.5) 45%, rgba(11,6,16,.72)), linear-gradient(120deg, rgba(123,44,191,.4), transparent 55%); }
.showcase__inner { position: relative; z-index: 2; padding-block: clamp(3.5rem, 9vw, 8rem); }
.showcase__kicker { font-size: .8rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--violet-bright); margin-bottom: 1.2rem; }
.showcase__title { font-family: var(--serif); font-weight: 330; font-size: clamp(2.2rem, 6.5vw, 5rem); line-height: 1.02; letter-spacing: -.02em; color: #fff; margin-bottom: 2rem; }
.showcase__title em { font-style: italic; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.showcase .btn-line { color: #fff; border-color: rgba(255,255,255,.5); }
.showcase .btn-line:hover { color: var(--violet-bright); border-color: var(--violet-bright); }

@media (max-width: 560px) {
  .feature img { height: 280px; }
  .showcase { min-height: 60vh; }
}

/* ============================================================
   REVEAL base
   ============================================================ */
.reveal { opacity: 0; transform: translateY(34px); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .col-aside, .col-main { grid-column: 1 / 13; }
  .kicker { margin-bottom: 1.5rem; }
  .values, .steps { grid-template-columns: repeat(2, 1fr); }
  .value, .step { border-right: none; }
  .value:nth-child(odd), .step:nth-child(odd) { border-right: 1px solid var(--line); }
  .contact__grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .nav { position: fixed; inset: 0; background: var(--bg); display: flex; align-items: center; justify-content: center; transform: translateX(100%); transition: transform .55s var(--ease); }
  .menu-open .nav { transform: translateX(0); }
  .nav__list { flex-direction: column; gap: 2rem; text-align: center; }
  .nav__list a { font-size: 1.6rem; font-family: var(--serif); color: var(--ink); }
  .burger { display: block; }
  .link-cta, .hero__scroll { display: none; }
  .hero__foot { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 560px) {
  .values, .steps { grid-template-columns: 1fr; }
  .value, .step { border-right: none !important; border-bottom: 1px solid var(--line); }
  .svc { grid-template-columns: 2.5rem 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
