/* =========================================================
   AURORA — Design Tokens
   ========================================================= */
:root{
  --bg:            #F8F5F3;
  --surface:       #F2EDF7;
  --card:          #FFFFFF;
  --ink:           #2F2945;
  --ink-soft:      #6E6685;
  --accent:        #5951A6;
  --accent-2:      #7A69D6;
  --lavender:      #C4A4FF;
  --warm:          #E7B7A5;

  --radius-lg:     32px;
  --radius-md:     28px;
  --radius-sm:     18px;
  --radius-pill:   999px;

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --ease: cubic-bezier(.22,.61,.22,1);
  --ease-soft: cubic-bezier(.16,.84,.44,1);

  --gutter: clamp(44px, 6vw, 116px);
  --menu-offset: 20px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; }
html::-webkit-scrollbar{ display:none; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{ font-family:var(--serif); font-weight:400; margin:0; color:var(--ink); }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:var(--sans); border:none; background:none; cursor:pointer; color:inherit; }
input{ font-family:var(--sans); }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
}

/* focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible{
  outline:2px solid var(--accent-2);
  outline-offset:3px;
  border-radius:6px;
}

/* =========================================================
   Nav fade — masks scrolled content so nothing shows
   sharply above/behind the floating nav pill
   ========================================================= */
.nav-fade{
  position:fixed; top:0; left:0; right:0;
  height:130px;
  background:linear-gradient(to bottom, var(--bg) 0%, var(--bg) 35%, rgba(248,245,243,0) 100%);
  z-index:90;
  pointer-events:none;
}

/* =========================================================
   Cursor glow — ambient "alive" layer
   ========================================================= */
.cursor-glow{
  position:fixed; top:0; left:0; width:520px; height:520px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(196,164,255,0.16) 0%, rgba(196,164,255,0) 70%);
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:1;
  transition:opacity .4s var(--ease);
  will-change:transform;
}
@media (max-width:900px){ .cursor-glow{ display:none; } }

/* =========================================================
   Eyebrow / labels
   ========================================================= */
.eyebrow{
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
}
.eyebrow-dash{ padding-left:22px; position:relative; }
.eyebrow-dash::before{
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:14px; height:1px; background:var(--ink-soft);
}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px;
  border-radius:var(--radius-pill);
  font-size:14px; font-weight:500; letter-spacing:.02em;
  transition:transform .45s var(--ease-soft), box-shadow .45s var(--ease-soft), background .45s var(--ease-soft);
  position:relative;
}
.btn svg{ transition:transform .4s var(--ease-soft); }
.btn-primary{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color:#fff;
  box-shadow:0 8px 24px -8px rgba(89,81,166,.55);
}
.btn-primary:hover{
  box-shadow:0 14px 34px -10px rgba(89,81,166,.65);
  transform:translateY(-2px);
}
.btn-primary:hover svg{ transform:translate(2px,-2px); }
.btn-ghost{
  background:transparent;
  color:var(--ink-soft);
  border:1px solid rgba(110,102,133,.25);
}
.btn-outline{
  background:transparent;
  color:var(--accent);
  border:1.5px solid var(--accent);
  transition:background .35s var(--ease-soft), color .35s var(--ease-soft);
}
.btn-outline:hover{
  background:var(--accent);
  color:#fff;
}
.btn-ghost:hover{ color:var(--ink); border-color:var(--ink-soft); }

.link-arrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink);
  padding:12px 20px;
  border:1px solid rgba(47,41,69,.14);
  border-radius:var(--radius-pill);
  transition:background .4s var(--ease-soft), border-color .4s var(--ease-soft);
}
.link-arrow:hover{ background:var(--card); border-color:transparent; box-shadow:0 6px 18px -8px rgba(47,41,69,.2); }

/* =========================================================
   Glass surfaces
   ========================================================= */
.glass{
  background:rgba(248,245,243,.62);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid rgba(255,255,255,.5);
}
.glass-solid{
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border:1px solid rgba(255,255,255,.7);
}

/* =========================================================
   Navigation
   ========================================================= */
.nav-wrap{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; justify-content:center;
  padding:var(--menu-offset) var(--menu-offset) 0;
  pointer-events:none;
}
.nav{
  pointer-events:all;
  width:100%; max-width:1640px;
  display:flex; align-items:center; justify-content:space-between;
  padding:5px 5px 5px 24px;
  border-radius:var(--radius-pill);
  box-shadow:0 10px 40px -18px rgba(47,41,69,.18);
  transition:box-shadow .4s var(--ease);
}
.nav-logo{ display:flex; align-items:center; margin-right:auto; }
.nav-logo-img{ height:35px; width:auto; display:block; transform-origin:center; transition:transform .3s var(--ease-soft); }
.nav-links{ display:flex; align-items:center; gap:36px; margin-right:32px; }
.nav-link{
  font-size:13.5px; font-weight:500; color:var(--ink);
  letter-spacing:.02em;
  position:relative;
  padding:4px 0;
}
.nav-link::after{
  content:''; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--accent); transition:width .35s var(--ease-soft);
}
.nav-link:hover::after{ width:100%; }
.nav-home-link{
  display:flex; align-items:center;
  color:rgba(150,145,165,.45);
  transform:translateY(1px);
  transition:color .3s var(--ease);
}
.nav-home-link::after{ display:none; }
.nav-home-link:hover{ color:rgba(150,145,165,.8); }
.nav-actions{ display:flex; align-items:center; gap:10px; }

.menu-toggle{
  width:31px; height:31px; border-radius:50%;
  background:transparent;
  border:1.5px solid var(--accent);
  display:flex; align-items:center; justify-content:center; gap:2px;
  transition:background .4s var(--ease-soft);
}
.menu-toggle-dot{ width:3px; height:3px; border-radius:50%; background:var(--accent); }

@media (max-width:880px){
  .nav-links{ display:none; }
  .nav{ padding:10px 10px 10px 20px; }
}

/* =========================================================
   Menu dropdown — compact panel below the hamburger
   ========================================================= */
.menu-overlay{
  position:fixed; inset:0; z-index:200;
  visibility:hidden;
  pointer-events:none;
  background:rgba(47,41,69,.14);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  opacity:0;
  transition:opacity .35s var(--ease-soft), visibility .35s;
}
.menu-overlay.open{ visibility:visible; pointer-events:all; opacity:1; }

.menu-panel{
  position:absolute;
  top:96px;
  right:calc(var(--menu-offset) + 5px);
  width:min(290px, 86vw);
  border-radius:var(--radius-lg);
  padding:26px 26px 28px;
  box-shadow:0 30px 70px -24px rgba(47,41,69,.4);
  transform-origin:top right;
  transform:scale(.9) translateY(-10px);
  opacity:0;
  transition:transform .45s var(--ease-soft), opacity .4s var(--ease-soft);
}
.menu-overlay.open .menu-panel{ transform:scale(1) translateY(0); opacity:1; }

.menu-panel-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:52px;
}
.menu-panel-logo{ height:39px; width:auto; display:block; }
.menu-panel-close{
  width:32px; height:32px; border-radius:50%;
  background:var(--accent); color:#fff;
  display:flex; align-items:center; justify-content:center;
  transition:transform .3s var(--ease-soft), background .3s var(--ease-soft);
}
.menu-panel-close:hover{ background:var(--accent-2); }

.menu-panel-links{ display:flex; flex-direction:column; gap:4px; }
.menu-link{
  font-family:var(--sans);
  font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink);
  padding:17px 2px;
  transition:color .3s var(--ease), padding-left .3s var(--ease-soft);
}
.menu-link:hover{ color:var(--accent); padding-left:6px; }

.menu-panel-footer{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:44px;
}

.lang-flags{ display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.flag-dot{
  width:13px; height:13px; border-radius:50%;
  display:block;
  overflow:hidden;
  border:none;
  background-size:cover;
  background-position:center;
  opacity:.5;
  box-shadow:
    inset 0 1px 2px rgba(0,0,0,.4),
    inset 0 -1px 1.5px rgba(255,255,255,.35),
    0 1px 3px rgba(47,41,69,.2);
  transition:transform .3s var(--ease-soft), box-shadow .3s var(--ease-soft), opacity .3s var(--ease-soft);
}
.flag-dot:hover{
  opacity:.85;
  transform:translateY(-2px) scale(1.14);
  box-shadow:
    inset 0 1px 2px rgba(0,0,0,.4),
    inset 0 -1px 1.5px rgba(255,255,255,.35),
    0 6px 14px -4px rgba(89,81,166,.55);
}
.flag-dot.active{
  opacity:1;
  transform:translateY(-2px) scale(1.14);
  box-shadow:
    inset 0 1px 2px rgba(0,0,0,.4),
    inset 0 -1px 1.5px rgba(255,255,255,.35),
    0 6px 14px -4px rgba(89,81,166,.55);
}

.flag-dot[data-lang="pl"]{ background-image:url('https://flagcdn.com/w80/pl.png'); }
.flag-dot[data-lang="en"]{ background-image:url('https://flagcdn.com/w80/gb.png'); }
.flag-dot[data-lang="de"]{ background-image:url('https://flagcdn.com/w80/de.png'); }
.flag-dot[data-lang="ja"]{ background-image:url('https://flagcdn.com/w80/jp.png'); }
.flag-dot[data-lang="zh"]{ background-image:url('https://flagcdn.com/w80/cn.png'); }
.flag-dot[data-lang="es"]{ background-image:url('https://flagcdn.com/w80/es.png'); }
.flag-dot[data-lang="th"]{ background-image:url('https://flagcdn.com/w80/th.png'); }

/* Discreet studio lock — intentionally understated */
.studio-lock{
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:transparent;
  border:none;
  color:rgba(110,102,133,.4);
  transition:color .35s var(--ease);
  flex-shrink:0;
}
.studio-lock:hover{ color:rgba(110,102,133,.75); }

@media (max-width:600px){
  .menu-panel{ top:88px; right:16px; left:16px; width:auto; }
}

/* =========================================================
   Dialogs (login / studio) — frosted glass sheets
   ========================================================= */
.dialog-backdrop{
  position:fixed; inset:0; z-index:650;
  background:rgba(47,41,69,.32);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  opacity:0; visibility:hidden;
  transition:opacity .45s var(--ease-soft), visibility .45s;
}
.dialog-backdrop.open{ opacity:1; visibility:visible; }

.dialog{
  border-radius:var(--radius-lg);
  padding:44px;
  box-shadow:0 30px 80px -24px rgba(47,41,69,.35);
  position:relative;
  transform:scale(.92) translateY(16px);
  opacity:0;
  transition:transform .5s var(--ease-soft), opacity .5s var(--ease-soft);
}
.dialog-backdrop.open .dialog{ transform:scale(1) translateY(0); opacity:1; }
.dialog-sm{ width:100%; max-width:400px; }

.dialog-close{
  position:absolute; top:20px; right:20px;
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--surface); color:var(--ink-soft);
  transition:transform .3s var(--ease-soft), background .3s var(--ease-soft);
}
.dialog-close:hover{ background:#fff; color:var(--accent); }

.dialog-title{ font-size:30px; margin:6px 0 26px; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.field label{ font-size:12px; color:var(--ink-soft); letter-spacing:.05em; text-transform:uppercase; }
.field input{
  padding:14px 18px; border-radius:var(--radius-sm);
  border:1px solid rgba(47,41,69,.12);
  background:var(--surface);
  font-size:14px; color:var(--ink);
  transition:border-color .3s var(--ease);
}
.field input:focus{ border-color:var(--accent-2); outline:none; }
.field input.field-error{
  border-color:#D97757;
  animation:fieldShake .4s var(--ease-soft);
}
@keyframes fieldShake{
  0%,100%{ transform:translateX(0); }
  25%{ transform:translateX(-6px); }
  75%{ transform:translateX(6px); }
}
.dialog-actions{ display:flex; gap:12px; }
.dialog-actions .btn{ flex:1; justify-content:center; }
.forgot-link{
  display:block; text-align:center; margin-top:22px;
  font-size:12px; color:rgba(110,102,133,.45);
  transition:color .3s var(--ease);
}
.forgot-link:hover{ color:var(--ink-soft); }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  padding:150px var(--gutter) 90px;
  max-width:1440px; margin:0 auto;
}
.hero-scroll-tag{
  position:fixed; left:var(--menu-offset); top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  writing-mode:vertical-rl;
  font-size:11px; letter-spacing:.18em; color:var(--ink-soft); font-weight:500;
  z-index:60;
}
.hero-scroll-line{ width:1px; height:46px; background:rgba(110,102,133,.3); }
@media (max-width:1100px){ .hero-scroll-tag{ display:none; } }

.hero-grid{
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:40px;
}
.hero-title{
  margin-top:20px;
  font-size:clamp(42px, 5.4vw, 74px);
  line-height:1.06;
  letter-spacing:-.01em;
}
.hero-title em{
  font-style:italic; font-weight:400;
  background:linear-gradient(100deg, var(--accent) 10%, var(--accent-2) 60%, var(--lavender) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub{
  margin-top:28px; max-width:440px;
  font-size:16px; line-height:1.7; color:var(--ink-soft);
}
.hero-cta{ margin-top:40px; }

.hero-art{
  position:relative; height:560px;
  display:flex; align-items:center; justify-content:center;
}
.sculpture{ width:100%; height:100%; }
.sculpture-svg{ width:100%; height:100%; }

.s-shard-a{ transform-origin:260px 260px; animation:rotateSlow 34s linear infinite; }
.s-shard-b{ transform-origin:260px 260px; animation:rotateSlow 28s linear infinite reverse; }
.s-shard-c{ animation:breathe 7s ease-in-out infinite; transform-origin:290px 330px; }

@keyframes rotateSlow{ from{ transform:rotate(0deg); } to{ transform:rotate(360deg); } }
@keyframes breathe{ 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.05); } }

.pantone-card{
  position:absolute; top:3.5%; right:2%;
  padding:20px 22px 28px; border-radius:var(--radius-sm);
  width:150px;
  border:1px solid rgba(47,41,69,.14);
  background:transparent;
}
.pantone-eyebrow{ font-size:10.5px; color:var(--ink-soft); line-height:1.4; margin-bottom:10px; }
.pantone-brand{ font-size:11px; font-weight:700; letter-spacing:.06em; color:var(--ink); margin-bottom:8px; }
.pantone-brand span{ font-size:8px; vertical-align:super; }
.pantone-name{ font-family:var(--serif); font-size:19px; margin-bottom:10px; }
.pantone-swatch-row{ display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.pantone-swatch{ width:16px; height:16px; border-radius:50%; border:1px solid rgba(47,41,69,.14); flex-shrink:0; }
.pantone-hex{ font-size:11px; color:var(--ink-soft); letter-spacing:.02em; }
.pantone-code{ font-size:11px; color:var(--ink-soft); }

.exp-badge{
  position:absolute; bottom:6%; right:0%;
  width:118px; height:118px; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  box-shadow:0 20px 50px -18px rgba(47,41,69,.28);
}
.exp-num{ font-family:var(--serif); font-size:26px; color:var(--accent); }
.exp-label{ font-size:9.5px; text-align:center; color:var(--ink-soft); line-height:1.3; letter-spacing:.03em; }

.float-slow{ animation:floatY 8s ease-in-out infinite; }
.float-slow-alt{ animation:floatY 9s ease-in-out infinite 1s; }
@keyframes floatY{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }

@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ height:420px; margin-top:20px; }
  .pantone-card{ display:none; }
}

/* =========================================================
   Work section — cards
   ========================================================= */
.work-section{
  padding:70px var(--gutter) 120px;
  max-width:1440px; margin:0 auto;
}
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:44px; gap:24px; flex-wrap:wrap;
}
.section-title{ font-size:clamp(32px, 3.6vw, 46px); margin-top:10px; }

.cards-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
}
.work-card{
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--card);
  box-shadow:0 24px 60px -30px rgba(47,41,69,.22);
  transition:transform .55s var(--ease-soft), box-shadow .55s var(--ease-soft);
  display:flex; flex-direction:column;
}
.work-card:hover{
  transform:translateY(-6px);
  box-shadow:0 34px 80px -28px rgba(47,41,69,.32);
}
.work-card-media{ aspect-ratio:4/3; overflow:hidden; position:relative; }
.media-fill{
  width:100%; height:100%;
  transition:transform 1.1s var(--ease-soft);
}
.work-card:hover .media-fill{ transform:scale(1.06); }
.media-static{ background:linear-gradient(135deg,#7A69D6 0%, #4A4380 100%); }
.media-anim{ background:linear-gradient(135deg,#E7B7A5 0%, #7A69D6 55%, #2F2945 100%); }
.media-rive{ background:linear-gradient(135deg,#5951A6 0%, #2F2945 100%); }

.work-card-body{ padding:30px 30px 34px; position:relative; display:flex; flex-direction:column; flex:1; }
.work-card-num{ font-size:12px; color:var(--ink-soft); margin-bottom:10px; letter-spacing:.05em; }
.work-card-body h3{ font-size:27px; margin-bottom:8px; }
.work-card-desc{ font-size:14px; color:var(--ink-soft); line-height:1.6; max-width:90%; margin-bottom:15px; }
.work-card-cta{
  display:inline-flex; align-items:center; gap:8px;
  align-self:flex-start;
  margin-top:auto; padding:11px 20px;
  border-radius:var(--radius-pill);
  background:var(--surface);
  font-size:12.5px; font-weight:500;
  transition:background .4s var(--ease-soft), color .4s var(--ease-soft), transform .4s var(--ease-soft);
}
.work-card:hover .work-card-cta{
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#fff; transform:translateX(3px);
}

@media (max-width:980px){
  .cards-grid{ grid-template-columns:1fr; }
  .work-card-cta{ margin-top:22px; }
}

/* =========================================================
   About teaser
   ========================================================= */
.about-teaser{
  padding:0 var(--gutter) 130px;
  max-width:1440px; margin:0 auto;
}
.about-grid{
  border-radius:var(--radius-lg);
  background:var(--surface);
  padding:56px;
  display:grid;
  grid-template-columns:.8fr 1.1fr 1fr;
  gap:48px;
  align-items:center;
}
.portrait-frame{
  aspect-ratio:3/4; border-radius:var(--radius-md);
  background:linear-gradient(160deg, #D8CDEF 0%, #B8A8DE 45%, #E7B7A5 100%);
}
.quote-mark{ color:var(--lavender); line-height:0; margin-bottom:14px; }
.quote-mark .quote-icon{ width:64px; height:auto; display:block; }
.about-quote{ font-family:var(--serif); font-size:clamp(24px, 2.6vw, 32px); line-height:1.35; }
.about-quote em{ font-style:italic; color:var(--accent); }
.signature{ display:block; margin-top:22px; font-family:var(--serif); font-style:italic; font-size:19px; color:var(--ink-soft); }

.about-services-text{ font-size:14.5px; line-height:1.75; color:var(--ink-soft); margin-bottom:28px; }
.programs-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px 16px; list-style:none; margin:0; padding:0; }
.program-chip{
  display:flex; align-items:center; gap:10px;
  font-size:12.5px; font-weight:500;
  min-width:0;
}
.program-chip span:last-child{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.program-chip-ico{
  width:30px; height:30px; border-radius:9px;
  background:#fff; display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-size:12px;
  box-shadow:0 6px 14px -8px rgba(47,41,69,.25);
  flex-shrink:0;
  overflow:hidden;
}
.program-chip-ico img{ width:100%; height:100%; object-fit:contain; padding:5px; box-sizing:border-box; }

@media (max-width:980px){
  .about-grid{ grid-template-columns:1fr; padding:36px; }
}

/* =========================================================
   Footer
   ========================================================= */
.footer{
  padding:50px var(--gutter) 60px;
  max-width:1440px; margin:0 auto;
  display:flex; flex-direction:column; gap:36px;
}
.footer-marquee{
  display:flex; flex-wrap:wrap; gap:10px; align-items:center;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft);
  border-top:1px solid rgba(47,41,69,.1);
  padding-top:26px;
}
.footer-marquee .dot{ color:var(--lavender); }
.footer-cta a{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--serif); font-size:clamp(24px, 4vw, 40px);
  transition:gap .4s var(--ease-soft), color .4s var(--ease);
}
.footer-cta a:hover{ gap:20px; color:var(--accent); }

/* =========================================================
   Testimonial card — shared across project modal, Clients page
   ========================================================= */
.testimonial-card{
  background:var(--surface);
  border-radius:var(--radius-sm);
  padding:30px 32px 26px;
}
.testimonial-quote-mark{
  color:var(--lavender);
  display:block;
  line-height:0;
  margin-bottom:10px;
}
.testimonial-quote-mark .quote-icon{ width:44px; height:auto; display:block; }
.testimonial-text{ font-size:14.5px; line-height:1.75; color:var(--ink); margin-bottom:18px; font-style:italic; }
.testimonial-author{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.testimonial-name{ font-size:13px; font-weight:600; }
.testimonial-role{ font-size:11.5px; color:var(--ink-soft); }
.testimonial-logo{ font-size:11px; font-weight:700; letter-spacing:.06em; color:var(--ink-soft); opacity:.7; }
.testimonial-logo img{ max-height:20px; max-width:80px; object-fit:contain; display:block; }

/* =========================================================
   Scroll position dots — replaces the scrollbar, aligned
   with the hamburger button
   ========================================================= */
.scroll-dots{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  right:calc(var(--menu-offset) + 8px);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  z-index:150;
  opacity:0;
  transition:opacity .4s var(--ease-soft);
}
.scroll-dots.visible{ opacity:1; }
.scroll-dot{
  width:5px; height:5px;
  border-radius:50%;
  background:rgba(47,41,69,.18);
  transition:background .35s var(--ease-soft), transform .35s var(--ease-soft);
}
.scroll-dot.active{
  background:var(--accent);
  transform:scale(1.7);
}

@media (max-width:680px){
  .scroll-dots{ display:none; }
}
/* =========================================================
   Reveal-on-scroll
   ========================================================= */
[data-reveal]{
  opacity:0; transform:translateY(28px);
  transition:opacity .9s var(--ease-soft), transform .9s var(--ease-soft);
}
[data-reveal].in-view{ opacity:1; transform:translateY(0); }
