/* =========================================================
   BARABAS OFFICE SERVICE — Design System
   Typography: DM Sans (display) + Manrope (body)
   Palette: Deep navy + champagne gold + cream
   ========================================================= */

/* ---- Tokens ---- */
:root{
  --navy-900:#070f24;
  --navy-800:#0a1b3d;
  --navy-700:#0d2148;
  --navy-600:#162a5a;
  --gold-500:#c9a04a;
  --gold-400:#d8b366;
  --gold-300:#e3c47e;
  --gold-200:#efd99e;
  --cream-50:#faf6ee;
  --cream-100:#f4ecda;
  --cream-200:#ece1c5;
  --paper:#f7f3ec;
  --ink:#0a1530;
  --ink-soft:#1c2742;
  --mute:#5b6378;
  --line:rgba(10,21,48,.12);
  --line-dark:rgba(255,255,255,.12);

  --ff-display:"DM Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --ff-body:"Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
  --ff-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --shell:1280px;
  --gutter:clamp(1.25rem, 4vw, 3rem);
  --radius-sm:6px;
  --radius:14px;
  --radius-lg:26px;

  --t-fast:160ms cubic-bezier(.2,.7,.3,1);
  --t-base:280ms cubic-bezier(.2,.7,.3,1);
  --t-slow:520ms cubic-bezier(.2,.7,.3,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--gold-500);color:var(--navy-900)}

/* ---- Type ---- */
h1,h2,h3,h4{
  font-family:var(--ff-display);
  font-weight:700;
  letter-spacing:-0.035em;     /* tight tracking as requested */
  line-height:.98;
  margin:0;
  color:var(--ink);
}
h3{letter-spacing:-0.03em;line-height:1.04}
h4{letter-spacing:-0.02em;font-weight:600;line-height:1.15}

.h-display{
  font-size:clamp(3rem, 8.4vw, 7.5rem);
  font-weight:700;
  letter-spacing:-0.048em;
  line-height:.9;
}
.h-1{font-size:clamp(2.4rem, 5.4vw, 4.6rem)}
.h-2{font-size:clamp(2rem, 4vw, 3.4rem)}
.h-3{font-size:clamp(1.35rem, 2.2vw, 1.85rem)}
.eyebrow{
  font-family:var(--ff-mono);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--mute);
}
.eyebrow.gold{color:var(--gold-500)}
p{margin:0}
.lede{
  font-size:clamp(1.05rem, 1.4vw, 1.2rem);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:60ch;
}
.serif-i{font-family:Georgia,"Times New Roman",serif;font-style:italic;font-weight:400}

/* ---- Shell ---- */
.shell{
  width:100%;
  max-width:var(--shell);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{padding:clamp(4rem,9vw,8rem) 0;position:relative}
.section-tight{padding:clamp(2.5rem,5vw,4rem) 0}
.dark{background:var(--navy-800);color:var(--cream-50)}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.dark .lede{color:rgba(255,255,255,.78)}
.dark .eyebrow{color:rgba(255,255,255,.62)}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.95rem 1.5rem;
  border-radius:999px;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:-0.005em;
  transition:transform var(--t-fast), background-color var(--t-fast), color var(--t-fast), box-shadow var(--t-base);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--navy-800);color:#fff}
.btn-primary:hover{background:var(--navy-700);box-shadow:0 18px 30px -18px var(--navy-800)}
.btn-gold{background:var(--gold-500);color:var(--navy-900)}
.btn-gold:hover{background:var(--gold-400);box-shadow:0 18px 30px -16px rgba(201,160,74,.7)}
.btn-ghost{background:transparent;color:inherit;border:1px solid var(--line)}
.dark .btn-ghost{border-color:var(--line-dark)}
.btn-ghost:hover{background:rgba(10,21,48,.05)}
.dark .btn-ghost:hover{background:rgba(255,255,255,.06)}
.btn .arrow{transition:transform var(--t-fast)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-sm{padding:.65rem 1.1rem;font-size:.85rem}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;
  border-bottom:1px solid currentColor;
  padding-bottom:2px;
  transition:gap var(--t-fast);
}
.link-arrow:hover{gap:.85rem}

/* ---- Nav ---- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(247,243,236,.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem var(--gutter);
  max-width:var(--shell);
  margin:0 auto;
  gap:2rem;
}
.brand{display:flex;align-items:center;gap:.6rem}
.brand img{height:38px;width:auto}
.nav-list{
  display:flex;align-items:center;gap:2.1rem;
  list-style:none;margin:0;padding:0;
  font-size:.94rem;font-weight:500;
}
.nav-list a{position:relative;padding:.3rem 0;transition:color var(--t-fast)}
.nav-list a::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;
  height:2px;background:var(--gold-500);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-base);
}
.nav-list a:hover::after,.nav-list a[aria-current]::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:.75rem}
.nav-toggle{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--line);align-items:center;justify-content:center}
.nav-toggle svg{width:18px;height:18px}

@media (max-width:920px){
  .nav-list,.nav-cta .btn-ghost{display:none}
  .nav-toggle{display:flex}
}

.mobile-menu{
  position:fixed;inset:0;z-index:60;
  background:var(--navy-900);color:#fff;
  display:flex;flex-direction:column;padding:1.25rem var(--gutter) 2rem;
  transform:translateY(-100%);
  transition:transform var(--t-slow);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem}
.mobile-menu-top img{height:34px;filter:invert(1)}
.mobile-menu ul{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}
.mobile-menu a{
  font-family:var(--ff-display);
  font-size:clamp(2rem,7vw,3.2rem);
  font-weight:700;letter-spacing:-0.04em;line-height:1;
  padding:.4rem 0;display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--line-dark);
}
.mobile-menu a span{font-family:var(--ff-mono);font-size:.85rem;letter-spacing:.15em;color:var(--gold-400)}
.mobile-foot{margin-top:auto;display:grid;gap:1rem}

/* ---- Hero ---- */
.hero{
  position:relative;
  padding:clamp(3rem,7vw,6rem) 0 clamp(3rem,8vw,7rem);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1200px 600px at 80% 0%, rgba(201,160,74,.10), transparent 65%),
    radial-gradient(900px 600px at 10% 100%, rgba(10,27,61,.05), transparent 60%);
  pointer-events:none;
}
.hero-inner{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(2rem,4vw,4rem);
  align-items:end;
  position:relative;
}
.hero-meta{
  display:flex;align-items:center;gap:1rem;margin-bottom:1.6rem;
  flex-wrap:wrap;
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--gold-500);box-shadow:0 0 0 6px rgba(201,160,74,.18)}
.hero h1{margin-bottom:1.5rem}
.hero h1 .accent{
  position:relative;display:inline-block;
  color:var(--gold-500);
  font-style:italic;font-weight:600;
}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;
  height:.08em;background:var(--gold-500);opacity:.35;
}
.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:2rem}
.hero-trust{
  margin-top:2.6rem;
  display:flex;flex-wrap:wrap;gap:1.6rem 2.2rem;
  border-top:1px solid var(--line);padding-top:1.4rem;
}
.hero-trust > div{display:flex;flex-direction:column;gap:.15rem}
.hero-trust strong{
  font-family:var(--ff-display);font-size:1.6rem;letter-spacing:-0.03em;
}
.hero-trust span{font-size:.82rem;color:var(--mute);letter-spacing:.04em}

.hero-visual{position:relative}
.hero-visual .frame{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:4/5;
  background:#0a1530;
  transform:translateY(0);
}
.hero-visual .frame img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95) contrast(1.02);
}
.hero-badge{
  position:absolute;left:-2rem;bottom:2.5rem;
  background:var(--navy-800);color:#fff;
  padding:1.1rem 1.3rem;border-radius:var(--radius);
  display:flex;align-items:center;gap:.85rem;
  box-shadow:0 30px 50px -25px rgba(10,21,48,.5);
  max-width:280px;
}
.hero-badge .ico{
  width:42px;height:42px;border-radius:12px;
  background:var(--gold-500);color:var(--navy-900);
  display:grid;place-items:center;
}
.hero-badge strong{display:block;font-family:var(--ff-display);letter-spacing:-0.02em;font-size:1rem;line-height:1.1}
.hero-badge span{font-size:.78rem;color:rgba(255,255,255,.7);display:block;margin-top:2px}

.hero-seal{
  position:absolute;right:-1.5rem;top:-1.5rem;
  width:148px;height:148px;
  display:grid;place-items:center;
  color:var(--navy-800);
  animation:spin 30s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-seal svg{width:100%;height:100%}

@media (max-width:880px){
  .hero-inner{grid-template-columns:1fr;gap:2.6rem}
  .hero-visual .frame{aspect-ratio:5/4}
  .hero-seal{width:104px;height:104px;right:-.5rem;top:-3rem}
  .hero-badge{left:1rem;bottom:1rem;max-width:260px}
}

/* ---- Marquee ---- */
.marquee{
  background:var(--navy-800);color:#fff;
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  overflow:hidden;padding:1.3rem 0;
}
.marquee-track{
  display:flex;gap:3rem;width:max-content;
  animation:marquee 32s linear infinite;
  font-family:var(--ff-display);
  font-weight:700;letter-spacing:-0.03em;font-size:clamp(1.3rem,2.4vw,2rem);
}
.marquee-track span{display:flex;align-items:center;gap:3rem;white-space:nowrap}
.marquee-track i{color:var(--gold-500);font-style:normal;font-size:.7em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- Services ---- */
.services-head{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:end;
  margin-bottom:clamp(2.5rem,5vw,4.5rem);
}
@media (max-width:780px){.services-head{grid-template-columns:1fr;gap:1.5rem}}

.svc-list{
  list-style:none;padding:0;margin:0;
  border-top:1px solid var(--line);
}
.svc-row{
  display:grid;
  grid-template-columns:80px 1.2fr 2fr auto;
  gap:2rem;align-items:center;
  padding:1.8rem 0;
  border-bottom:1px solid var(--line);
  position:relative;
  transition:padding var(--t-base);
}
.svc-row:hover{padding-left:1.2rem}
.svc-row::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:3px;
  background:var(--gold-500);transform:scaleY(0);transform-origin:top;
  transition:transform var(--t-base);
}
.svc-row:hover::before{transform:scaleY(1)}

.svc-num{
  font-family:var(--ff-display);
  font-size:1.05rem;font-weight:500;letter-spacing:.04em;
  color:var(--mute);
}
.svc-title{
  font-family:var(--ff-display);
  font-size:clamp(1.4rem,2.6vw,2.05rem);
  letter-spacing:-0.035em;
  font-weight:700;line-height:1.02;
}
.svc-desc{color:var(--ink-soft);font-size:.98rem;line-height:1.5;max-width:54ch}
.svc-go{
  width:48px;height:48px;border-radius:50%;
  background:var(--cream-50);
  display:grid;place-items:center;
  transition:background var(--t-base), transform var(--t-base);
  border:1px solid var(--line);
}
.svc-row:hover .svc-go{background:var(--gold-500);transform:rotate(-45deg)}
.svc-go svg{width:18px;height:18px}

@media (max-width:880px){
  .svc-row{
    display:flex;
    flex-direction:column;
    gap:.5rem;
    padding:1.6rem 0;
    text-align:left;
    align-items:flex-start;
  }
  .svc-num{order:1}
  .svc-title{order:2;text-align:left}
  .svc-desc{order:3;font-size:.92rem;text-align:left}
  .svc-go{display:none}
}

/* ---- Stats ---- */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
}
.stat{
  padding:2.4rem 1.6rem;
  border-right:1px solid var(--line-dark);
  display:flex;flex-direction:column;gap:.4rem;
}
.stat:last-child{border-right:0}
.stat-num{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(2.4rem,5vw,4rem);
  letter-spacing:-0.05em;line-height:.9;
  color:#fff;
  display:flex;align-items:flex-start;gap:.2rem;
}
.stat-num small{font-size:.4em;color:var(--gold-400);margin-top:.25em}
.stat-label{font-size:.85rem;color:rgba(255,255,255,.7);letter-spacing:.02em}
@media (max-width:780px){
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line-dark)}
}

/* ---- Process ---- */
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
  margin-top:clamp(2rem,4vw,3.5rem);
}
.step{
  position:relative;
  padding:1.8rem 1.4rem 1.6rem;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;flex-direction:column;gap:.85rem;
  transition:transform var(--t-base), border-color var(--t-base);
}
.step:hover{transform:translateY(-4px);border-color:var(--gold-500)}
.step-num{
  width:42px;height:42px;border-radius:12px;
  background:var(--navy-800);color:#fff;
  display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:700;font-size:1.05rem;
}
.step h3{font-size:1.2rem;letter-spacing:-0.025em}
.step p{font-size:.92rem;color:var(--mute);line-height:1.5}
.step .arc{
  position:absolute;right:-1rem;top:50%;transform:translateY(-50%);
  width:2rem;height:2px;background:var(--gold-500);
  display:none;
}
@media(min-width:881px){
  .step:not(:last-child) .arc{display:block}
}
@media(max-width:880px){
  .process-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  .process-grid{grid-template-columns:1fr}
}

/* ---- About snippet ---- */
.about{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);
  align-items:center;
}
.about-img{
  position:relative;
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;background:var(--cream-100);
}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-tag{
  position:absolute;bottom:1.4rem;left:1.4rem;right:1.4rem;
  background:rgba(7,15,36,.8);backdrop-filter:blur(10px);
  color:#fff;padding:1rem 1.2rem;border-radius:var(--radius);
  display:flex;align-items:center;gap:.9rem;
}
.about-tag .stamp{
  width:46px;height:46px;border-radius:50%;
  border:1.5px solid var(--gold-500);color:var(--gold-400);
  display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:700;font-size:.78rem;line-height:1;
  text-align:center;
}
.about-tag strong{font-family:var(--ff-display);font-size:1rem;letter-spacing:-0.02em;line-height:1.1}
.about-tag span{font-size:.78rem;color:rgba(255,255,255,.7)}
.about-content h2{margin-bottom:1.2rem}
.about-bullets{
  list-style:none;padding:0;margin:1.6rem 0 2rem;
  display:grid;gap:1.1rem;
}
.about-bullets li{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  font-size:1rem;
  line-height:1.5;
}
.about-bullets li svg{
  flex-shrink:0;
  width:20px;
  height:20px;
  margin-top:.25em;
  color:var(--gold-500);
}
.about-bullets li div{
  display:flex;
  flex-direction:column;
  gap:.15rem;
}
.about-bullets li strong{
  color:var(--ink);
  font-weight:600;
}
.about-bullets li span{
  color:var(--ink-soft);
  font-size:.95rem;
}
@media(max-width:880px){
  .about{grid-template-columns:1fr;gap:2.5rem}
  .about-img{aspect-ratio:5/4;max-width:100%}
}
@media(max-width:520px){
  .about-bullets{gap:1.2rem}
  .about-bullets li svg{width:18px;height:18px}
  .about-bullets li span{font-size:.9rem}
}

/* ---- FAQ ---- */
.faq-grid{display:grid;grid-template-columns:1fr 2fr;gap:clamp(2rem,5vw,4rem)}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr}}
.faq-list{display:grid;gap:.5rem}
.faq{
  border:1px solid var(--line);background:#fff;
  border-radius:var(--radius);
  transition:border-color var(--t-base), box-shadow var(--t-base);
}
.faq[open]{border-color:var(--navy-700);box-shadow:0 16px 40px -22px var(--navy-800)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:1.1rem 1.3rem;
  display:flex;justify-content:space-between;gap:1rem;align-items:center;
  font-family:var(--ff-display);font-weight:600;letter-spacing:-0.015em;
  font-size:1.05rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq .ico{
  flex:0 0 auto;width:28px;height:28px;border-radius:50%;
  background:var(--cream-100);display:grid;place-items:center;
  transition:transform var(--t-base), background var(--t-base);
}
.faq[open] .ico{background:var(--gold-500);transform:rotate(45deg)}
.faq-body{padding:0 1.3rem 1.2rem;color:var(--ink-soft);font-size:.96rem;line-height:1.6}

/* ---- Contact ---- */
.contact-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);
  align-items:start;
}
.contact-grid h2 .ph{
  display:block;font-family:var(--ff-display);font-weight:700;
  font-size:clamp(2rem,4.4vw,3.2rem);letter-spacing:-0.04em;
  color:var(--gold-400);margin-top:.6rem;
}
.contact-cards{display:grid;gap:.85rem}
.cc{
  display:flex;gap:1rem;align-items:center;
  padding:1.1rem 1.2rem;border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-dark);
  transition:background var(--t-base), border-color var(--t-base), transform var(--t-base);
}
.cc:hover{background:rgba(255,255,255,.07);border-color:var(--gold-500);transform:translateY(-2px)}
.cc .ico{
  width:44px;height:44px;border-radius:12px;
  background:rgba(201,160,74,.15);color:var(--gold-400);
  display:grid;place-items:center;flex:0 0 auto;
}
.cc strong{display:block;font-family:var(--ff-display);font-size:1rem;letter-spacing:-0.015em}
.cc span{font-size:.85rem;color:rgba(255,255,255,.6)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}

/* ---- Footer ---- */
.footer{background:var(--navy-900);color:rgba(255,255,255,.78);padding:4rem 0 2rem}
.footer-greet{
  font-family:var(--ff-display);
  font-size:clamp(2.6rem,7vw,5.5rem);
  font-weight:700;letter-spacing:-0.045em;line-height:.95;
  color:#fff;
  border-bottom:1px solid var(--line-dark);
  padding-bottom:2rem;margin-bottom:2rem;
}
.footer-greet em{font-style:normal;color:var(--gold-400)}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;
  padding-bottom:2.5rem;
  border-bottom:1px solid var(--line-dark);
}
.footer-grid h5{
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.45);
  margin:0 0 1rem;font-weight:500;
}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem;font-size:.92rem}
.footer-grid a:hover{color:var(--gold-400)}
.footer-brand img{height:38px;margin-bottom:1rem}
.footer-brand p{font-size:.92rem;max-width:38ch;color:rgba(255,255,255,.6)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.82rem;color:rgba(255,255,255,.45);padding-top:1.6rem;
  flex-wrap:wrap;gap:1rem;
}
.footer-bottom a:hover{color:#fff}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---- Floating WhatsApp ---- */
.wa-float{
  position:fixed;right:1.2rem;bottom:1.2rem;z-index:40;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -10px rgba(37,211,102,.5);
  transition:transform var(--t-fast);
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* ---- Page header (sub pages) ---- */
.page-head{
  background:var(--navy-800);color:#fff;
  padding:clamp(4rem,8vw,7rem) 0 clamp(3.5rem,7vw,6rem);
  position:relative;overflow:hidden;
}
.page-head::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 500px at 90% 0%, rgba(201,160,74,.18), transparent 60%);
  pointer-events:none;
}
.page-head .eyebrow{color:var(--gold-400)}
.page-head h1{color:#fff;max-width:18ch;margin:1rem 0 1.4rem}
.page-head .crumbs{
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.55);
}
.page-head .crumbs a:hover{color:#fff}

/* ---- Detailed Service Card (leistungen page) ---- */
.svc-detail{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;
  margin-bottom:1.5rem;
}
.svc-detail.reverse > div:first-child{order:2}
.svc-detail-img{
  min-height:280px;background:var(--cream-100);
  position:relative;overflow:hidden;
}
.svc-detail-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.svc-detail-body{padding:clamp(1.8rem,3.5vw,3rem)}
.svc-detail-body .tag{
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-500);margin-bottom:.6rem;
}
.svc-detail-body h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:1rem}
.svc-detail-body p{color:var(--ink-soft);margin-bottom:1.2rem;line-height:1.6}
.svc-detail-body ul{list-style:none;padding:0;margin:1rem 0 1.4rem;display:grid;gap:.5rem}
.svc-detail-body ul li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.svc-detail-body ul li::before{
  content:"";flex:0 0 auto;
  width:14px;height:14px;margin-top:.32em;
  border-radius:3px;background:var(--gold-500);
  background-image:linear-gradient(135deg, var(--gold-500), var(--gold-300));
}
@media(max-width:780px){
  .svc-detail{grid-template-columns:1fr}
  .svc-detail.reverse > div:first-child{order:0}
}

/* ---- Contact page form ---- */
.contact-page{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
@media(max-width:880px){.contact-page{grid-template-columns:1fr}}
.contact-info{display:grid;gap:1rem}
.contact-info .cc{background:#fff;border:1px solid var(--line);color:var(--ink)}
.contact-info .cc:hover{border-color:var(--gold-500);background:#fff}
.contact-info .cc strong{color:var(--ink)}
.contact-info .cc span{color:var(--mute)}
.contact-info .cc .ico{background:var(--cream-100);color:var(--navy-700)}

.form{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(1.8rem,3.5vw,2.6rem);
  display:grid;gap:1rem;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:520px){.form-row{grid-template-columns:1fr}}
.field{display:grid;gap:.4rem}
.field label{font-size:.85rem;color:var(--mute);font-weight:500;letter-spacing:.01em}
.field input,.field select,.field textarea{
  font:inherit;
  padding:.85rem 1rem;border-radius:10px;
  border:1px solid var(--line);background:var(--cream-50);
  transition:border-color var(--t-base), background var(--t-base);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--navy-700);background:#fff;
}
.field textarea{min-height:140px;resize:vertical;font-family:inherit}
.checkbox{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-soft)}
.checkbox input{width:18px;height:18px;margin-top:.2em}

/* ---- About page extras ---- */
.values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  margin-top:clamp(2rem,4vw,3rem);
}
.value{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.5rem;display:flex;flex-direction:column;gap:.8rem;
}
.value .ico{
  width:48px;height:48px;border-radius:12px;
  background:var(--cream-100);color:var(--navy-700);
  display:grid;place-items:center;
}
.value h3{font-size:1.15rem;letter-spacing:-0.02em}
.value p{font-size:.92rem;color:var(--mute);line-height:1.55}
@media(max-width:880px){.values{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.values{grid-template-columns:1fr}}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 800ms ease, transform 800ms cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---- Language switch (DE / RO) ---- */
.lang-switch{
  display:inline-flex;align-items:center;gap:.1rem;
  font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;
  border:1px solid var(--line);border-radius:999px;
  padding:.25rem .35rem;
  margin-right:.3rem;
}
.lang-switch a,.lang-switch span.cur{
  padding:.28rem .55rem;border-radius:999px;
  color:var(--mute);font-weight:500;line-height:1;
  transition:background var(--t-fast), color var(--t-fast);
}
.lang-switch a:hover{color:var(--ink);background:var(--cream-100)}
.lang-switch span.cur{color:var(--ink);background:var(--navy-800);color:#fff}
.dark .lang-switch,.page-head .lang-switch{border-color:var(--line-dark)}
.dark .lang-switch a,.page-head .lang-switch a{color:rgba(255,255,255,.6)}
.dark .lang-switch a:hover,.page-head .lang-switch a:hover{background:rgba(255,255,255,.08);color:#fff}
.dark .lang-switch span.cur,.page-head .lang-switch span.cur{background:var(--gold-500);color:var(--navy-900)}

.mobile-lang{
  display:flex;align-items:center;gap:.4rem;
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.5);
  margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid var(--line-dark);
}
.mobile-lang a{padding:.5rem .8rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;color:rgba(255,255,255,.7)}
.mobile-lang a:hover{color:#fff;border-color:var(--gold-500)}
.mobile-lang span.cur{padding:.5rem .8rem;background:var(--gold-500);color:var(--navy-900);border-radius:999px;font-weight:600}

@media (max-width:920px){.lang-switch{display:none}}

/* ---- Formulare page (Download cards) ---- */
.fm-grid{display:grid;gap:1.4rem;margin-top:clamp(2rem,4vw,3rem)}
.fm-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.4rem);
  display:grid;gap:1.6rem;
  transition:border-color var(--t-base), transform var(--t-base), box-shadow var(--t-base);
}
.fm-card:hover{border-color:var(--gold-400);transform:translateY(-2px);box-shadow:0 18px 40px -28px rgba(10,21,48,.35)}
.fm-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.fm-head-text{display:grid;gap:.4rem;min-width:0;flex:1 1 280px}
.fm-tag{
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-500);
}
.fm-card h2{font-size:clamp(1.4rem,2.4vw,1.8rem);letter-spacing:-0.02em}
.fm-sub{color:var(--mute);font-size:.95rem;margin:0}
.fm-status{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;
  background:var(--cream-100);color:var(--navy-700);
  padding:.45rem .75rem;border-radius:999px;
  white-space:nowrap;
}
.fm-status.online{background:rgba(201,160,74,.18);color:var(--navy-800)}
.fm-info{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
  padding-top:1.4rem;border-top:1px solid var(--line);
}
.fm-info-block{display:grid;gap:.5rem;align-content:start}
.fm-info-label{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute);margin:0;
}
.fm-info-block p{margin:0;font-size:.92rem;color:var(--ink-soft);line-height:1.55}
.fm-info-block ul{list-style:none;padding:0;margin:0;display:grid;gap:.35rem}
.fm-info-block ul li{display:flex;gap:.55rem;align-items:flex-start;font-size:.9rem;color:var(--ink-soft);line-height:1.5}
.fm-info-block ul li::before{
  content:"";flex:0 0 auto;width:6px;height:6px;margin-top:.55em;
  border-radius:50%;background:var(--gold-500);
}
.fm-cta{
  display:flex;gap:.7rem;flex-wrap:wrap;
  padding-top:1.4rem;border-top:1px solid var(--line);
  align-items:center;
}
.fm-cta .btn{font-size:.92rem}
.fm-cta .fm-source{
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);margin-left:auto;
}
.fm-cta .fm-source a{color:var(--mute);text-decoration:underline;text-underline-offset:3px}
.fm-cta .fm-source a:hover{color:var(--navy-800)}
@media(max-width:780px){
  .fm-info{grid-template-columns:1fr;gap:1.1rem}
  .fm-cta{flex-direction:column;align-items:stretch}
  .fm-cta .btn{justify-content:center}
  .fm-cta .fm-source{margin:0;text-align:center}
}

.fm-note{
  background:var(--cream-100);border:1px solid var(--cream-200);
  border-radius:var(--radius);
  padding:1.2rem 1.4rem;
  display:flex;gap:.8rem;align-items:flex-start;
  font-size:.92rem;color:var(--ink-soft);line-height:1.55;
  margin-top:clamp(2rem,4vw,3rem);
}
.fm-note svg{flex:0 0 auto;color:var(--gold-500);margin-top:.15em}
.fm-note strong{color:var(--ink)}

/* Print-friendly hidden helper */
.sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* =========================================================
   HERO DARK — navy-dominant variant
   ========================================================= */
.hero-dark{
  background:
    linear-gradient(180deg, var(--navy-900) 0%, var(--navy-800) 60%, var(--navy-700) 100%);
  color:#fff;
  border-bottom:1px solid var(--line-dark);
}
.hero-dark::before{
  background:
    radial-gradient(1100px 600px at 80% 0%, rgba(201,160,74,.22), transparent 60%),
    radial-gradient(800px 600px at 0% 100%, rgba(201,160,74,.08), transparent 60%);
}
.hero-dark h1,.hero-dark h2,.hero-dark h3{color:#fff}
.hero-dark h1 .accent{color:var(--gold-400)}
.hero-dark h1 .accent::after{background:var(--gold-400);opacity:.5}
.hero-dark .lede{color:rgba(255,255,255,.82)}
.hero-dark .lede strong{color:#fff}
.hero-dark .lede em{color:var(--gold-300)}
.hero-dark .eyebrow{color:rgba(255,255,255,.66)}
.hero-dark .hero-trust{border-top-color:var(--line-dark)}
.hero-dark .hero-trust strong{color:#fff}
.hero-dark .hero-trust span{color:rgba(255,255,255,.62)}
.hero-dark .btn-ghost{color:#fff;border-color:var(--line-dark)}
.hero-dark .btn-ghost:hover{background:rgba(255,255,255,.07)}
.hero-dark .hero-visual .frame{
  border:1px solid rgba(201,160,74,.25);
  box-shadow:0 50px 90px -30px rgba(0,0,0,.6);
}
.hero-dark .hero-seal{color:var(--gold-300);opacity:.85}
.hero-dark .hero-seal svg text[fill="#0a1b3d"]{fill:var(--gold-300)}
.hero-dark .hero-seal svg circle{stroke:var(--gold-400)}

/* =========================================================
   REVIEWS SECTION
   ========================================================= */
.reviews{background:var(--navy-900);color:#fff;position:relative;overflow:hidden}
.reviews::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(201,160,74,.10), transparent 60%),
    radial-gradient(700px 500px at 95% 100%, rgba(201,160,74,.07), transparent 55%);
  pointer-events:none;
}
.reviews .shell{position:relative;z-index:1}
.reviews-head{
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:end;
  margin-bottom:clamp(2.5rem,5vw,4rem);
}
@media(max-width:880px){.reviews-head{grid-template-columns:1fr;gap:1.8rem}}
.reviews-head h2{color:#fff}
.reviews-head .lede{color:rgba(255,255,255,.78)}
.reviews-stars{
  display:flex;align-items:center;gap:.7rem;margin-top:.6rem;
  font-family:var(--ff-mono);font-size:.85rem;letter-spacing:.12em;
  color:rgba(255,255,255,.75);text-transform:uppercase;
}
.reviews-stars svg{color:var(--gold-400);width:20px;height:20px}
.reviews-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
@media(max-width:1100px){.reviews-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}}
@media(max-width:600px){.reviews-grid{grid-template-columns:1fr}}
.review-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  padding:1.6rem 1.5rem;
  display:flex;flex-direction:column;gap:1rem;
  transition:border-color var(--t-base), transform var(--t-base), background var(--t-base);
}
.review-card:hover{border-color:var(--gold-500);transform:translateY(-4px);background:rgba(255,255,255,.06)}
.review-stars{display:flex;gap:.15rem;color:var(--gold-400)}
.review-stars svg{width:16px;height:16px}
.review-text{
  font-family:var(--ff-display);font-weight:500;
  font-size:1.02rem;line-height:1.5;letter-spacing:-0.01em;
  color:rgba(255,255,255,.92);
  margin:0;
}
.review-text::before{
  content:"";display:inline-block;
  width:24px;height:18px;
  margin-right:.3rem;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23c9a04a'><path d='M7.17 6C4.32 6 2 8.32 2 11.17v6.66h7V11.17H4.5c0-1.47 1.2-2.67 2.67-2.67V6zm10 0c-2.85 0-5.17 2.32-5.17 5.17v6.66h7V11.17H14.5c0-1.47 1.2-2.67 2.67-2.67V6z'/></svg>") no-repeat center/contain;
  vertical-align:middle;
}
.review-meta{
  display:flex;align-items:center;gap:.7rem;
  border-top:1px solid rgba(255,255,255,.1);padding-top:1rem;
}
.review-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg, var(--gold-400), var(--gold-500));
  color:var(--navy-900);
  display:grid;place-items:center;
  font-family:var(--ff-display);font-weight:700;font-size:1rem;letter-spacing:-0.02em;
}
.review-name{font-family:var(--ff-display);font-weight:600;font-size:.95rem;color:#fff}
.review-date{font-size:.78rem;color:rgba(255,255,255,.55);margin-top:1px}
.reviews-cta{
  margin-top:clamp(2rem,4vw,3rem);
  display:flex;align-items:center;justify-content:space-between;
  gap:1.4rem;flex-wrap:wrap;
  padding:1.4rem 1.6rem;
  background:rgba(201,160,74,.08);
  border:1px solid rgba(201,160,74,.25);
  border-radius:var(--radius);
}
.reviews-cta-text{display:flex;align-items:center;gap:1rem;flex:1 1 320px}
.reviews-cta-icon{
  width:48px;height:48px;border-radius:12px;flex:0 0 auto;
  background:linear-gradient(135deg, var(--gold-400), var(--gold-500));
  color:var(--navy-900);display:grid;place-items:center;
}
.reviews-cta strong{display:block;font-family:var(--ff-display);font-size:1.05rem;color:#fff;letter-spacing:-0.015em}
.reviews-cta span{font-size:.85rem;color:rgba(255,255,255,.65)}

/* =========================================================
   PARTNER (AMC mention card)
   ========================================================= */
.partner-card{
  margin-top:clamp(2rem,4vw,3rem);
  display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:center;
  padding:1.6rem 1.8rem;
  background:linear-gradient(135deg, var(--navy-800), var(--navy-700));
  color:#fff;
  border-radius:var(--radius-lg);
  border:1px solid rgba(201,160,74,.3);
  position:relative;overflow:hidden;
}
.partner-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--gold-300), var(--gold-500), var(--gold-300));
}
.partner-card-badge{
  width:64px;height:64px;border-radius:18px;flex:0 0 auto;
  background:linear-gradient(135deg, var(--gold-300), var(--gold-500));
  color:var(--navy-900);
  font-family:var(--ff-display);font-weight:800;font-size:1.35rem;
  letter-spacing:-0.04em;line-height:1;
  display:grid;place-items:center;
  box-shadow:0 12px 24px -10px rgba(201,160,74,.6);
}
.partner-card-logo{
  width:104px;height:104px;flex:0 0 auto;
  border-radius:18px;
  background:#fff;
  padding:.6rem;
  object-fit:contain;
  box-shadow:0 12px 24px -10px rgba(0,0,0,.35);
  border:1px solid rgba(201,160,74,.35);
}
.partner-card-phone{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:.9rem;
  padding:.55rem 1rem;
  background:rgba(201,160,74,.18);
  color:var(--gold-300);
  border:1px solid rgba(201,160,74,.4);
  border-radius:999px;
  font-family:var(--ff-display);
  font-weight:600;font-size:.92rem;
  letter-spacing:-0.005em;
  transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.partner-card-phone:hover{
  background:var(--gold-500);
  color:var(--navy-900);
  border-color:var(--gold-500);
}
.partner-card-phone svg{width:14px;height:14px}
.partner-card-body strong{
  display:block;font-family:var(--ff-display);
  font-size:1.15rem;letter-spacing:-0.02em;color:#fff;
  margin-bottom:.3rem;
}
.partner-card-body p{
  color:rgba(255,255,255,.78);font-size:.94rem;line-height:1.55;
}
.partner-card-tag{
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-300);margin-bottom:.4rem;
  display:inline-block;
}
@media(max-width:520px){
  .partner-card{grid-template-columns:1fr;text-align:center;padding:1.6rem 1.4rem}
  .partner-card-badge{margin:0 auto}
}

/* =========================================================
   LEGAL PARTNERS (recommended law firms · § 3 RDG compliance)
   ========================================================= */
.legal-partners{
  background:linear-gradient(180deg,#f8f6f0 0%,#fbf9f3 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.legal-partners-head{
  max-width:780px;margin:0 auto 2.6rem;text-align:center;
}
.legal-partners-disclaimer{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem 1.1rem;border-radius:999px;
  background:rgba(201,160,74,.14);
  border:1px solid rgba(201,160,74,.4);
  color:var(--navy-800);
  font-family:var(--ff-mono);font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  margin-bottom:1.2rem;
}
.legal-partners-disclaimer svg{width:14px;height:14px;color:var(--gold-500)}
.legal-partners-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem;
}
.legal-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:2rem 1.8rem;
  display:flex;flex-direction:column;gap:.85rem;
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.legal-card:hover{
  transform:translateY(-3px);
  box-shadow:0 28px 50px -28px rgba(10,21,48,.22);
  border-color:rgba(201,160,74,.5);
}
.legal-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--gold-300), var(--gold-500), var(--gold-300));
}
.legal-card-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg, var(--navy-800), var(--navy-700));
  color:var(--gold-300);
  display:grid;place-items:center;
  margin-bottom:.3rem;
  box-shadow:0 10px 22px -10px rgba(10,21,48,.4);
}
.legal-card-icon svg{width:26px;height:26px}
.legal-card-tag{
  font-family:var(--ff-mono);font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-500);margin:0;font-weight:600;
}
.legal-card h3{
  font-family:var(--ff-display);font-weight:600;
  font-size:1.25rem;letter-spacing:-.018em;
  color:var(--navy-900);margin:0;line-height:1.25;
}
.legal-card-specialty{
  font-size:.94rem;line-height:1.55;color:#1f2937;margin:0;
}
.legal-card-specialty strong{color:var(--navy-800);font-weight:600}
.legal-card-meta{
  display:flex;flex-direction:column;gap:.55rem;
  font-size:.92rem;color:#374151;
  border-top:1px solid var(--line);padding-top:1rem;margin-top:.5rem;
}
.legal-card-meta a{
  color:var(--navy-800);text-decoration:none;
  border-bottom:1px solid transparent;transition:border-color .15s ease;
}
.legal-card-meta a:hover{border-color:var(--gold-500)}
.legal-card-meta-row{
  display:flex;align-items:flex-start;gap:.6rem;
}
.legal-card-meta-row svg{
  width:16px;height:16px;flex:0 0 auto;color:var(--gold-500);margin-top:.18rem;
}
@media(max-width:780px){
  .legal-partners-grid{grid-template-columns:1fr;gap:1.2rem}
  .legal-card{padding:1.6rem 1.4rem}
}

/* =========================================================
   3-LANG SWITCH adjustments
   ========================================================= */
.lang-switch{padding:.22rem .3rem}
.lang-switch a,.lang-switch span.cur{padding:.26rem .5rem;font-size:.72rem}
@media(max-width:1100px){
  .lang-switch a,.lang-switch span.cur{padding:.24rem .42rem}
}
.mobile-lang{flex-wrap:wrap;gap:.5rem}
.mobile-lang a,.mobile-lang span.cur{padding:.5rem .85rem}

/* =========================================================
   SECTION VARIANT — navy soft (between cream and full dark)
   ========================================================= */
.section-navy-soft{
  background:linear-gradient(180deg, var(--navy-800), var(--navy-900));
  color:#fff;
  position:relative;overflow:hidden;
}
.section-navy-soft::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 500px at 90% 0%, rgba(201,160,74,.14), transparent 60%);
  pointer-events:none;
}
.section-navy-soft .shell{position:relative;z-index:1}
.section-navy-soft h1,.section-navy-soft h2,.section-navy-soft h3{color:#fff}
.section-navy-soft .lede{color:rgba(255,255,255,.78)}
.section-navy-soft .eyebrow{color:rgba(255,255,255,.6)}
.section-navy-soft .eyebrow.gold{color:var(--gold-300)}

