/* ================================================================
   GERMANIS v2 — "Interactive Document Desk"
   Kolorystyka: papier kremowy, atrament, czerwień urzędowa, złoto
   ================================================================ */

/* ---------- 1. RESET & TOKENS ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body,h1,h2,h3,h4,h5,h6,p,ul,ol,figure{margin:0}
ul,ol{padding:0;list-style:none}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
input,textarea,select{font:inherit;color:inherit}

:root{
  /* Paleta */
  --paper:       #FAF7F2;
  --paper-2:     #F3EEE2;
  --paper-dark:  #EAE2D0;
  --ink:         #0A0A0B;
  --ink-soft:    #2A2A32;
  --ink-muted:   #5C5C66;
  --ink-faded:   #8A8A94;
  --red:         #B91C1C;
  --red-bright:  #DC2626;
  --red-dark:    #8B1515;
  --gold:        #C9A85C;
  --gold-soft:   #E6D4A3;
  --line:        #E8E2D4;
  --white:       #FFFFFF;
  --shadow:      0 1px 2px rgba(10,10,11,.05), 0 8px 24px rgba(10,10,11,.08);
  --shadow-lg:   0 4px 10px rgba(10,10,11,.08), 0 20px 50px rgba(10,10,11,.12);
  --shadow-stamp:0 2px 4px rgba(185,28,28,.2);

  /* Typografia */
  --font-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:  'Space Grotesk', 'SF Mono', Menlo, monospace;
  --font-script:'Caveat', 'Brush Script MT', cursive;

  /* Rozmiary */
  --container: 1240px;
  --radius:    6px;
  --radius-lg: 12px;
  --radius-xl: 20px;

  /* Layout */
  --header-h:  76px;
  --topbar-h:  40px;
}

html,body{background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{min-height:100vh;overflow-x:hidden}

/* Paper texture background everywhere */
body{
  background-color:var(--paper);
  background-image:
    radial-gradient(ellipse at 20% 10%, rgba(201,168,92,.04), transparent 50%),
    radial-gradient(ellipse at 80% 60%, rgba(185,28,28,.03), transparent 50%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.7  0 0 0 0 0.65  0 0 0 0 0.55  0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-attachment:fixed,fixed,fixed;
}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--font-serif);font-weight:700;line-height:1.1;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,6vw,4.75rem);line-height:1.05}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.6rem)}
h4{font-size:1.15rem}

p{color:var(--ink-soft);font-size:1rem}
p.lead{font-size:1.15rem;color:var(--ink-muted);font-weight:400}

/* ---------- 2. REUSABLE PAPER ELEMENTS ---------- */

.label{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-weight:500;text-transform:uppercase;
  font-size:.78rem;letter-spacing:.2em;color:var(--red);
  margin-bottom:18px
}
.label::before{content:"";display:inline-block;width:28px;height:1px;background:var(--red)}

.handwritten{font-family:var(--font-script);font-weight:600;color:var(--red)}

.paper-card{
  background:var(--white);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  position:relative;
}
.paper-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='1.2' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.6  0 0 0 0 0.55  0 0 0 0 0.45  0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;opacity:.5;border-radius:inherit;
}

/* "Stamp" stickers */
.red-stamp{
  display:inline-flex;align-items:center;justify-content:center;
  border:2px solid var(--red);color:var(--red);
  padding:6px 14px;font-family:var(--font-mono);font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;
  border-radius:2px;transform:rotate(-2deg);
  background:rgba(185,28,28,.04);
  box-shadow:var(--shadow-stamp);
}
.red-stamp--check::before{content:"✓ ";font-weight:900;margin-right:4px}

.paper-edge{
  position:relative;
}
.paper-edge::before{
  content:"";position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(180deg,rgba(0,0,0,.06),transparent);
}

/* ---------- 3. BUTTONS ---------- */

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;font-weight:600;font-size:.95rem;
  border-radius:var(--radius);border:1.5px solid transparent;
  transition:all .2s ease;cursor:pointer;white-space:nowrap;
  font-family:var(--font-sans);letter-spacing:.01em;
}
.btn-lg{padding:17px 34px;font-size:1rem}
.btn-block{width:100%}

.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);box-shadow:0 10px 25px rgba(185,28,28,.3)}

.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-dark:hover{background:#1c1c22;transform:translateY(-2px)}

.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}

.btn-white{background:#fff;color:var(--ink);border-color:#fff}
.btn-white:hover{background:var(--paper);transform:translateY(-2px)}

.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}

/* ---------- 4. TOPBAR ---------- */

.topbar{
  background:var(--ink);color:rgba(255,255,255,.85);
  font-size:.82rem;height:var(--topbar-h);font-family:var(--font-mono)
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:20px}
.topbar-left{display:flex;gap:24px}
.topbar-link{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85);transition:color .15s}
.topbar-link:hover{color:var(--gold)}
.topbar-link i{font-size:.75rem;color:var(--gold)}
.topbar-stamp{display:inline-flex;align-items:center;gap:8px;color:var(--gold);letter-spacing:.15em;font-size:.72rem}
.topbar-stamp i{color:var(--gold)}
@media (max-width:680px){
  .topbar-right{display:none}
  .topbar-left{gap:10px}
  .topbar-link{font-size:.77rem}
  .topbar-link i{font-size:.8rem}
}
@media (max-width:430px){
  .topbar-link--phone{display:none}
}

/* ---------- 5. HEADER & NAV ---------- */

.header{
  position:sticky;top:0;z-index:50;background:var(--paper);
  border-bottom:1px solid var(--line);
  transition:all .25s ease;
}
.header.scrolled{background:rgba(250,247,242,.96);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line),0 6px 20px rgba(0,0,0,.05)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:var(--header-h)}
.logo{display:inline-flex;align-items:center}
.logo-img{height:44px;width:auto}

.nav-list{display:flex;gap:6px;align-items:center}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;padding:10px 16px;
  font-family:var(--font-mono);font-weight:500;font-size:.85rem;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);
  border-radius:var(--radius);transition:all .15s
}
.nav-link:hover,.nav-item.active>.nav-link{color:var(--red)}
.nav-item.active>.nav-link{background:rgba(185,28,28,.06)}
.nav-arrow{font-size:.6rem;transition:transform .2s}
.nav-item.has-dropdown:hover .nav-arrow{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:280px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:10px;box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all .18s;
}
.nav-item.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown::before{
  content:"";position:absolute;top:-8px;left:24px;
  border:6px solid transparent;border-bottom-color:#fff;border-top:0
}
.dropdown-link{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border-radius:var(--radius);font-size:.92rem;color:var(--ink-soft);
  transition:all .15s
}
.dropdown-link i{width:24px;color:var(--red);font-size:.95rem}
.dropdown-link:hover{background:var(--paper-2);color:var(--ink);padding-left:18px}

.header-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;padding:11px 22px;
  font-weight:600;font-size:.9rem;border-radius:var(--radius);
  transition:all .2s
}
.header-cta:hover{background:var(--red-dark);transform:translateY(-2px)}
.header-cta i{font-size:.75rem;transition:transform .2s}
.header-cta:hover i{transform:translateX(3px)}

.hamburger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.hamburger span{width:24px;height:2px;background:var(--ink);transition:.25s;transform-origin:center}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:1100px){
  .nav-desktop,.header-cta{display:none}
  .hamburger{display:flex}
}

/* Mobile nav */
.mobile-nav{position:fixed;top:0;right:-100%;width:85%;max-width:380px;height:100vh;background:var(--paper);z-index:100;padding:24px;overflow-y:auto;transition:right .3s;box-shadow:-10px 0 40px rgba(0,0,0,.1)}
.mobile-nav.active{right:0}
.mobile-nav-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.mobile-logo{height:38px}
.mobile-close{width:40px;height:40px;border-radius:50%;background:var(--paper-2);display:flex;align-items:center;justify-content:center}
.mobile-nav-list{display:flex;flex-direction:column;gap:4px}
.mobile-nav-item{position:relative;border-bottom:1px solid var(--line)}
.mobile-nav-link{display:block;padding:16px 8px;font-family:var(--font-serif);font-weight:700;font-size:1.15rem}
.mobile-toggle{position:absolute;right:0;top:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--red)}
.mobile-nav-item.has-children.open .mobile-toggle i{transform:rotate(45deg)}
.mobile-sub{max-height:0;overflow:hidden;transition:max-height .3s}
.mobile-nav-item.has-children.open .mobile-sub{max-height:400px}
.mobile-sub li a{display:flex;align-items:center;gap:10px;padding:12px 20px;color:var(--ink-soft);font-size:.95rem}
.mobile-sub li a i{color:var(--red);width:20px}
.mobile-nav-footer{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.mobile-contact-btn{display:flex;align-items:center;gap:10px;padding:14px;background:var(--white);border-radius:var(--radius);font-weight:500}
.mobile-contact-btn i{color:var(--red)}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;z-index:99;transition:.2s}
.mobile-overlay.active{opacity:1;visibility:visible}

/* ---------- 6. HERO — Biurko Tłumacza ---------- */

.hero{
  position:relative;padding:80px 0 120px;overflow:hidden;
}
.hero-lines{
  position:absolute;inset:0;
  background-image:repeating-linear-gradient(0deg,transparent 0 34px,rgba(185,28,28,.04) 34px 35px);
  pointer-events:none;z-index:0
}
.hero-margin{
  position:absolute;left:max(calc((100vw - var(--container))/2 + 60px), 60px);
  top:0;bottom:0;width:1px;background:rgba(185,28,28,.18);z-index:0;pointer-events:none
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;min-height:calc(100vh - var(--header-h) - var(--topbar-h) - 40px)}
.hero-text{max-width:620px}
.hero-pretitle{font-family:var(--font-script);font-size:2.4rem;color:var(--red);line-height:1;margin-bottom:12px;transform:rotate(-3deg);display:inline-block}
.hero-title{font-family:var(--font-serif);font-size:clamp(2.8rem,7vw,5.5rem);line-height:1;font-weight:900;margin-bottom:28px}
.hero-title .ink{color:var(--ink)}
.hero-title .red{color:var(--red);font-style:italic;font-weight:700}
.hero-title .underline{display:inline-block;position:relative}
.hero-title .underline::after{content:"";position:absolute;left:-4px;right:-8px;bottom:4px;height:10px;background:var(--gold-soft);z-index:-1;transform:skewX(-4deg);opacity:.7}
.hero-subtitle{font-size:1.15rem;color:var(--ink-muted);margin-bottom:38px;max-width:520px;line-height:1.55}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:54px}
.hero-stats{display:flex;gap:40px;padding:22px 28px;background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:var(--radius);max-width:620px;box-shadow:var(--shadow)}
.hero-stat-num{font-family:var(--font-serif);font-size:2.2rem;font-weight:900;color:var(--red);line-height:1}
.hero-stat-label{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-muted);margin-top:4px}

/* Document mockup */
.hero-visual{position:relative;height:520px;perspective:1600px}
.doc-stack{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.doc{
  position:absolute;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
  padding:28px;font-size:12px;color:var(--ink-muted);line-height:1.5;
  border-radius:2px;
}
.doc-back{width:74%;height:72%;right:2%;top:6%;transform:rotate(4deg)}
.doc-mid{width:74%;height:72%;left:-2%;top:14%;transform:rotate(-3deg)}
.doc-front{width:76%;height:78%;left:12%;top:8%;transform:rotate(1.5deg);z-index:2}
.doc-header{font-family:var(--font-serif);font-weight:900;font-size:16px;color:var(--ink);text-transform:uppercase;letter-spacing:.15em;padding-bottom:10px;border-bottom:2px double var(--ink);margin-bottom:14px}
.doc-line{height:6px;background:repeating-linear-gradient(90deg,var(--paper-2) 0 20px,transparent 20px 22px);margin-bottom:10px;width:100%;border-radius:1px}
.doc-line.short{width:62%}
.doc-line.med{width:80%}
.doc-sig{margin-top:18px;font-family:var(--font-script);font-size:22px;color:var(--ink);transform:rotate(-4deg)}
.doc-stamp{position:absolute;right:-20px;bottom:-10px;width:130px;height:130px;animation:stampSpin 40s linear infinite;filter:drop-shadow(0 4px 12px rgba(185,28,28,.25))}
@keyframes stampSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.hero-pagemark{position:absolute;right:24px;bottom:24px;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-faded);letter-spacing:.2em;z-index:3}

@media(max-width:900px){
  .hero{padding:56px 0 80px}
  .hero-inner{grid-template-columns:1fr;gap:40px;min-height:auto}
  .hero-visual{height:380px;order:-1}
  .hero-stats{flex-wrap:wrap;gap:24px;padding:18px 22px}
  .hero-margin{display:none}
}
@media(max-width:540px){
  .hero-stats{gap:18px}
  .hero-stat-num{font-size:1.7rem}
  .hero-buttons .btn{flex:1;min-width:0}
}

/* ---------- 7. ABOUT — Akta ---------- */

.section{padding:100px 0;position:relative}
.section-header{text-align:center;max-width:720px;margin:0 auto 64px}
.section-header h2{margin-bottom:16px}
.section-header .label{justify-content:center}
.section-header p{color:var(--ink-muted);font-size:1.05rem}

.about-wrap{position:relative;max-width:1100px;margin:0 auto;padding:60px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lg);border-radius:var(--radius)}
.about-wrap::before{
  content:"";position:absolute;top:20px;left:20px;right:20px;bottom:20px;border:1px solid var(--paper-dark);pointer-events:none;border-radius:2px;
}
.about-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:56px;align-items:center;position:relative}
.about-img{position:relative;overflow:hidden;border-radius:2px}
.about-img img{width:100%;height:auto;display:block;filter:saturate(.9) contrast(1.02)}
.about-img::after{content:"";position:absolute;top:0;right:0;width:70px;height:70px;background:linear-gradient(-45deg,var(--paper) 50%,transparent 50%);filter:drop-shadow(-2px 2px 6px rgba(0,0,0,.1))}
.about-stamp{position:absolute;bottom:-20px;left:-20px;width:120px;height:120px;transform:rotate(-12deg)}
.about-content .label{color:var(--red)}
.about-content h2{margin-bottom:20px}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin:28px 0}
.about-feature{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border:1.5px solid var(--red);color:var(--red);background:rgba(185,28,28,.03);font-family:var(--font-mono);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;border-radius:3px;transform:rotate(-1deg)}
.about-feature:nth-child(even){transform:rotate(1deg)}
.about-feature::before{content:"✓";font-weight:900}
.about-sign{margin-top:22px;display:flex;align-items:baseline;gap:10px;font-family:var(--font-script);font-size:1.6rem;color:var(--ink);padding-top:18px;border-top:1px dashed var(--line)}
.about-sign span{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.18em;color:var(--ink-muted);text-transform:uppercase}
@media(max-width:880px){
  .about-wrap{padding:36px 22px}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-features{grid-template-columns:1fr}
  .about-stamp{width:90px;height:90px;bottom:-12px;left:-12px}
}

/* ---------- 8. SERVICES — Archiwum ---------- */

.services-section{padding:120px 0;position:relative;overflow:hidden;background:var(--paper-2)}
.services-section::before{
  content:"ARCHIWUM";position:absolute;top:8%;left:50%;
  transform:translateX(-50%) rotate(-6deg);
  font-family:var(--font-serif);font-weight:900;font-size:clamp(180px,28vw,420px);
  color:rgba(10,10,11,.03);letter-spacing:-.04em;pointer-events:none;z-index:0;line-height:1
}
.services-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,4fr) minmax(0,6fr);gap:80px;align-items:flex-start}
.services-sticky{position:sticky;top:calc(var(--header-h) + 40px);padding-right:10px}
.services-sticky-label{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.services-sticky h2{font-size:clamp(2rem,3.6vw,3rem);margin-bottom:18px}
.services-preview{
  margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);position:relative;min-height:320px;overflow:hidden
}
.services-preview-img{aspect-ratio:16/10;background:var(--paper-2);border-radius:3px;margin-bottom:20px;overflow:hidden;position:relative}
.services-preview-img img{width:100%;height:100%;object-fit:cover;transition:opacity .3s}
.services-preview-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;margin-bottom:10px;transition:opacity .3s}
.services-preview-desc{color:var(--ink-muted);font-size:.95rem;margin-bottom:18px;transition:opacity .3s}
.services-preview-cta{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-weight:600;font-size:.95rem}
.services-preview-cta i{transition:transform .2s}
.services-preview-cta:hover i{transform:translateX(4px)}

/* Rows list */
.services-rows{display:flex;flex-direction:column;border-top:1px solid var(--ink)}
.service-row{
  display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:22px;
  padding:30px 0;border-bottom:1px solid var(--ink);
  transition:all .3s ease;cursor:pointer;position:relative;
}
.service-row::before{
  content:"";position:absolute;inset:0;background:rgba(185,28,28,.03);opacity:0;transition:opacity .3s;z-index:-1
}
.service-row.active::before,.service-row:hover::before{opacity:1}
.services-rows:hover .service-row:not(:hover){opacity:.4}
.service-row-num{font-family:var(--font-mono);font-size:1.1rem;font-weight:500;color:var(--ink-faded);letter-spacing:.12em;min-width:44px}
.service-row-title{font-family:var(--font-serif);font-size:clamp(1.5rem,3.2vw,2.6rem);font-weight:700;line-height:1.1;transition:color .25s}
.service-row.active .service-row-title,.service-row:hover .service-row-title{color:var(--red)}
.service-row-thumb{
  width:0;height:70px;border-radius:3px;overflow:hidden;
  transition:width .35s cubic-bezier(.3,.8,.3,1);opacity:0
}
.service-row.active .service-row-thumb,.service-row:hover .service-row-thumb{width:110px;opacity:1}
.service-row-thumb img{width:100%;height:100%;object-fit:cover}
.service-row-arrow{color:var(--ink);opacity:.3;transition:all .2s}
.service-row:hover .service-row-arrow{opacity:1;color:var(--red);transform:translateX(4px)}

@media(max-width:980px){
  .services-inner{grid-template-columns:1fr;gap:40px}
  .services-sticky{position:static}
  .services-preview{display:none}
  .service-row{grid-template-columns:auto 1fr auto;padding:22px 0}
  .service-row-title{font-size:1.4rem}
  .service-row-thumb{display:none}
}

/* ---------- 9. PROCESS — Pieczątki ---------- */

.process-section{padding:120px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.process-section .label{color:var(--gold)}
.process-section .label::before{background:var(--gold)}
.process-section h2{color:#fff}
.process-section .section-header p{color:rgba(255,255,255,.7)}

.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
.process-step{
  position:relative;padding:36px 26px 30px;background:var(--paper);color:var(--ink);
  border-radius:4px;transform:rotate(-1.5deg);transition:transform .3s;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.process-step:nth-child(even){transform:rotate(1.2deg)}
.process-step:hover{transform:rotate(0) translateY(-6px)}
.process-step-num{font-family:var(--font-serif);font-weight:900;font-size:3.4rem;color:var(--red);line-height:1;margin-bottom:8px}
.process-step h4{font-family:var(--font-serif);font-size:1.3rem;margin-bottom:10px}
.process-step p{font-size:.92rem;color:var(--ink-muted)}
.process-step-stamp{
  position:absolute;top:-14px;right:-10px;
  font-family:var(--font-mono);font-weight:700;font-size:.7rem;
  color:var(--red);border:1.5px solid var(--red);padding:5px 9px;
  transform:rotate(8deg);letter-spacing:.1em;background:rgba(250,247,242,.95)
}
@media(max-width:860px){.process-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.process-grid{grid-template-columns:1fr}}

/* ---------- 10. STUDIA — Pocztówka ---------- */

.postcard-section{padding:120px 0;position:relative}
.postcard{
  max-width:1050px;margin:0 auto;background:#fff;
  border:1px solid var(--line);border-radius:3px;
  display:grid;grid-template-columns:1fr 1fr;min-height:420px;
  box-shadow:var(--shadow-lg);transform:rotate(-1deg);transition:transform .3s;
  position:relative
}
.postcard:hover{transform:rotate(0)}
.postcard::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;
  background:repeating-linear-gradient(180deg,var(--line) 0 6px,transparent 6px 12px);
  pointer-events:none
}
.postcard-left{padding:50px 40px;background:linear-gradient(160deg,var(--paper-2),var(--paper));border-right:1px dashed transparent;position:relative}
.postcard-stamp-de{position:absolute;top:24px;right:24px;width:90px;height:110px;border:2px solid var(--ink);background:var(--red);color:#fff;padding:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-family:var(--font-mono);transform:rotate(4deg)}
.postcard-stamp-de .big{font-size:1.2rem;font-weight:700}
.postcard-stamp-de .small{font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;margin-top:4px;opacity:.9}
.postcard-img{width:100%;aspect-ratio:4/3;background:var(--paper-dark);border-radius:2px;overflow:hidden;margin-top:40px}
.postcard-img img{width:100%;height:100%;object-fit:cover;filter:sepia(.15) saturate(.9)}
.postcard-right{padding:50px 40px;background:
  repeating-linear-gradient(0deg,transparent 0 28px,var(--paper-2) 28px 29px) #fff}
.postcard-handwritten{font-family:var(--font-script);font-size:2.6rem;color:var(--red);line-height:1.1;margin-bottom:18px;transform:rotate(-1deg)}
.postcard-right p{color:var(--ink-soft);font-size:1rem;margin-bottom:14px}
.postcard-right .btn{margin-top:20px}
@media(max-width:780px){
  .postcard{grid-template-columns:1fr;transform:none}
  .postcard::before{display:none}
  .postcard-left{padding:36px 28px}
  .postcard-right{padding:30px 28px}
  .postcard-img{margin-top:16px}
  .postcard-stamp-de{width:74px;height:90px}
}

/* ---------- 11. BIO — Frontispiece ---------- */

.bio-section{padding:120px 0;background:var(--paper-2);position:relative}
.bio-wrap{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:64px;align-items:center}
.bio-img-wrap{position:relative}
.bio-img{aspect-ratio:4/5;border-radius:999px / 500px;overflow:hidden;border:2px solid var(--ink);background:var(--paper);box-shadow:var(--shadow-lg);max-width:360px;margin:0 auto}
.bio-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.05)}
.bio-img-wrap::before{content:"";position:absolute;top:-20px;left:50%;transform:translateX(-50%);width:calc(100% - 40px);max-width:340px;aspect-ratio:4/5;border:1px solid var(--line);border-radius:inherit;pointer-events:none}
.bio-year{position:absolute;bottom:30px;left:-10px;font-family:var(--font-serif);font-size:4rem;font-weight:900;color:var(--red);line-height:1;transform:rotate(-6deg)}
.bio-year small{display:block;font-size:.7rem;font-family:var(--font-mono);color:var(--ink-muted);letter-spacing:.2em;text-transform:uppercase;font-weight:400;margin-top:4px}
.bio-content h2{margin-bottom:20px;font-size:clamp(2.2rem,4.5vw,3.4rem)}
.bio-highlight{color:var(--red);font-weight:600}
.bio-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.bio-tag{display:inline-flex;align-items:center;padding:6px 14px;background:#fff;border:1.5px solid var(--ink);color:var(--ink);font-family:var(--font-mono);font-weight:600;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;border-radius:2px}
.bio-tag:nth-child(odd){transform:rotate(-1deg)}
.bio-tag:nth-child(even){transform:rotate(1deg)}
@media(max-width:820px){.bio-wrap{grid-template-columns:1fr;gap:32px;text-align:center}.bio-tags{justify-content:center}}

/* ---------- 12. TESTIMONIALS — Corkboard ---------- */

.testimonials-section{padding:120px 0;background:linear-gradient(135deg,#7a4e2c 0%,#8d5b34 100%);position:relative;overflow:hidden}
.testimonials-section::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='2.5' numOctaves='3'/><feColorMatrix values='0 0 0 0 0.4  0 0 0 0 0.25  0 0 0 0 0.1  0 0 0 0.4 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;opacity:.6
}
.testimonials-section .label{color:#fff}
.testimonials-section .label::before{background:#fff}
.testimonials-section h2,.testimonials-section .section-header p{color:#fff;position:relative;z-index:1}
.testimonials-section .section-header p{color:rgba(255,255,255,.85)}
.testimonials-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1080px;margin:0 auto}
.testimonial-card{
  position:relative;background:var(--paper);padding:28px 26px 24px;
  border-radius:2px;box-shadow:0 14px 32px rgba(0,0,0,.25);
  transform:rotate(var(--r,0deg));
}
.testimonial-card:nth-child(1){--r:-2deg}
.testimonial-card:nth-child(2){--r:1deg}
.testimonial-card:nth-child(3){--r:-1deg}
.testimonial-card:nth-child(4){--r:2deg}
.testimonial-card:nth-child(5){--r:-1.5deg}
.testimonial-card:nth-child(6){--r:1.5deg}
.testimonial-card::before{content:"";position:absolute;top:-10px;left:50%;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#e94c4c,#8b1515);box-shadow:0 3px 6px rgba(0,0,0,.4);transform:translateX(-50%)}
.testimonial-stars{display:flex;gap:3px;margin-bottom:12px;color:var(--red)}
.testimonial-text{font-family:var(--font-serif);font-size:1.05rem;color:var(--ink);margin-bottom:14px;line-height:1.5;font-style:italic}
.testimonial-author{font-family:var(--font-mono);font-weight:600;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}
.testimonial-author::before{content:"— "}
@media(max-width:860px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.testimonials-grid{grid-template-columns:1fr}}

/* ---------- 13. CTA BANNER ---------- */

.cta-banner{position:relative;padding:90px 0;background:var(--red);color:#fff;overflow:hidden}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(-45deg,transparent 0 24px,rgba(255,255,255,.04) 24px 26px)
}
.cta-inner{position:relative;z-index:1;text-align:center;max-width:720px;margin:0 auto}
.cta-inner h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin-bottom:14px}
.cta-inner p{color:rgba(255,255,255,.9);font-size:1.1rem;margin-bottom:30px}
.cta-buttons{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.cta-stamp{position:absolute;top:30px;right:clamp(20px,6%,80px);width:140px;height:140px;border:2px solid rgba(255,255,255,.5);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(-14deg);font-family:var(--font-mono);color:#fff;padding:18px}
.cta-stamp .big{font-family:var(--font-serif);font-size:2rem;font-weight:900;line-height:1}
.cta-stamp .small{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;margin-top:6px;text-align:center;opacity:.9}
@media(max-width:720px){.cta-stamp{display:none}}

/* ---------- 14. FORMULARZ ---------- */

.contact-section{padding:120px 0;background:var(--paper-2)}
.contact-section--dark{background:var(--ink);color:#fff}
.contact-section--dark .label{color:#fca5a5}
.contact-section--dark .label::before{background:#fca5a5}
.contact-section--dark h2{color:#fff}
.contact-section--dark p{color:rgba(255,255,255,.7)}

.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:56px;align-items:start}
.contact-info-cards{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.contact-info-card{display:flex;gap:16px;align-items:flex-start;padding:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.contact-section--dark .contact-info-card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.contact-info-icon{width:44px;height:44px;border-radius:50%;background:rgba(185,28,28,.08);color:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-section--dark .contact-info-icon{background:rgba(252,165,165,.12);color:#fca5a5}
.contact-info-text h4{font-family:var(--font-sans);font-weight:600;font-size:.9rem;margin-bottom:2px}
.contact-info-text p,.contact-info-text a{font-size:.92rem;color:var(--ink-muted)}
.contact-section--dark .contact-info-text p,.contact-section--dark .contact-info-text a{color:rgba(255,255,255,.75)}

.contact-form-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px;position:relative;box-shadow:var(--shadow-lg)}
.contact-form-header{border-bottom:2px double var(--ink);padding-bottom:16px;margin-bottom:24px;display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.contact-form-header h3{font-family:var(--font-serif);font-size:1.45rem;margin:0;text-transform:uppercase;letter-spacing:.03em}
.contact-form-ref{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;color:var(--red);text-transform:uppercase}
.contact-form-intro{font-size:.9rem;color:var(--ink-muted);margin-bottom:24px;font-style:italic}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-group{display:flex;flex-direction:column;margin-bottom:18px}
.form-group label{font-family:var(--font-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-muted);margin-bottom:6px}
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group input[type="file"],
.form-group textarea{
  background:transparent;border:0;border-bottom:1.5px solid var(--ink);
  padding:10px 4px;font-size:1rem;color:var(--ink);
  border-radius:0;transition:border-color .15s,background .15s;
  font-family:var(--font-sans);
}
.form-group input:focus,.form-group textarea:focus{outline:0;border-bottom-color:var(--red);background:rgba(185,28,28,.02)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--ink-faded);font-weight:300}
.form-group textarea{resize:vertical;min-height:110px}
.form-group input[type="file"]{padding:12px 0;border:1.5px dashed var(--ink-faded);background:var(--paper-2);padding:14px;border-radius:var(--radius);font-family:var(--font-mono);font-size:.8rem}
.form-group input[type="file"]:hover{border-color:var(--red)}

.form-consent{display:flex;gap:12px;align-items:flex-start;margin:18px 0 22px;padding:14px;background:var(--paper-2);border-radius:var(--radius);border:1px dashed var(--line)}
.form-consent input{margin-top:3px;width:20px;height:20px;accent-color:var(--red)}
.form-consent label{font-size:.82rem;color:var(--ink-muted);line-height:1.5;cursor:pointer}

.form-status{margin-top:16px;padding:14px;border-radius:var(--radius);font-size:.92rem;display:none}
.form-status.success{display:block;background:#ecfdf5;border:1px solid #10b981;color:#065f46}
.form-status.error{display:block;background:#fef2f2;border:1px solid #ef4444;color:#991b1b}
.form-status.loading{display:block;background:var(--paper-2);border:1px solid var(--line);color:var(--ink-muted)}

@media(max-width:820px){
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-form-wrap{padding:26px 22px}
  .form-row{grid-template-columns:1fr}
}

/* ---------- 15. FOOTER ---------- */

.footer{background:var(--ink);color:rgba(255,255,255,.72);padding:70px 0 0;position:relative}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:repeating-linear-gradient(90deg,var(--red) 0 24px,var(--gold) 24px 48px,var(--ink) 48px 72px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px}
.footer-logo img{height:56px;filter:brightness(0) invert(1);margin-bottom:16px;opacity:.9}
.footer-about{font-size:.9rem;line-height:1.6;margin-bottom:18px;color:rgba(255,255,255,.6)}
.footer-seal{display:flex;align-items:center;gap:12px;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);max-width:240px}
.footer-seal img{filter:invert(1) sepia(1) saturate(10) hue-rotate(-10deg);opacity:.9}
.footer-seal-num{font-family:var(--font-serif);font-weight:900;font-size:1.1rem;color:#fff}
.footer-seal-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.footer-heading{font-family:var(--font-serif);color:#fff;font-size:1.05rem;margin-bottom:18px;position:relative;padding-bottom:10px}
.footer-heading::after{content:"";position:absolute;bottom:0;left:0;width:28px;height:2px;background:var(--red)}
.footer-links li,.footer-contact li{margin-bottom:10px;font-size:.9rem}
.footer-links a:hover{color:var(--red-bright);padding-left:6px;transition:.15s}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;line-height:1.4}
.footer-contact i{color:var(--red-bright);width:16px;margin-top:3px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.5);font-family:var(--font-mono);letter-spacing:.08em}
.footer-tp{color:var(--gold-soft)}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}.footer-bottom-inner{justify-content:center;text-align:center}}

/* ---------- 16. PAGE HERO (podstrony) ---------- */

.page-hero{
  position:relative;padding:60px 0 70px;background:var(--paper-2);
  border-bottom:1px solid var(--line);overflow:hidden
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(0deg,transparent 0 40px,rgba(185,28,28,.04) 40px 41px);pointer-events:none
}
.page-hero-inner{position:relative;z-index:1;max-width:900px}
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-muted);letter-spacing:.08em;text-transform:uppercase}
.breadcrumb a{color:var(--red)}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{color:var(--ink-faded)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:14px}
.page-hero-desc{color:var(--ink-muted);font-size:1.08rem;max-width:640px}
.page-hero-stamp{position:absolute;right:5%;top:30%;width:150px;height:150px;opacity:.55;transform:rotate(-10deg);pointer-events:none}
@media(max-width:820px){.page-hero-stamp{display:none}}

/* ---------- 17. SERVICE DETAIL + SIDEBAR ---------- */

.service-detail{padding:90px 0}
.service-detail-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:56px;align-items:start}
.service-detail-content{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:44px;box-shadow:var(--shadow)}
.service-detail-img{margin:-44px -44px 36px;overflow:hidden}
.service-detail-img img{width:100%;height:auto;display:block}
.service-detail-content h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:18px}
.service-detail-content h3{margin:26px 0 12px}
.service-detail-content p{margin-bottom:16px;font-size:1rem}
.feature-list{display:flex;flex-direction:column;gap:12px;margin:22px 0}
.feature-list li{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-left:3px solid var(--red);background:rgba(185,28,28,.04);font-size:.95rem}
.feature-list li i{color:var(--red);margin-top:3px}

.service-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:calc(var(--header-h) + 20px)}
.sidebar-card{background:#fff;border:1px solid var(--line);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow);position:relative}
.sidebar-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;color:var(--red);text-transform:uppercase;margin-bottom:10px}
.sidebar-card h4{font-family:var(--font-serif);font-size:1.1rem;margin-bottom:16px;padding-bottom:10px;border-bottom:2px double var(--ink)}
.sidebar-nav li a{display:flex;align-items:center;gap:12px;padding:12px 10px;border-radius:var(--radius);color:var(--ink-soft);font-size:.92rem;transition:all .15s;border-bottom:1px dashed var(--line)}
.sidebar-nav li:last-child a{border-bottom:0}
.sidebar-nav li a:hover,.sidebar-nav li a.active{background:var(--paper-2);color:var(--red);padding-left:14px}
.sidebar-num{font-family:var(--font-mono);font-weight:700;color:var(--ink-faded);font-size:.8rem;min-width:28px}
.sidebar-title{flex:1}
.sidebar-nav li a i{opacity:.3;transition:.15s}
.sidebar-nav li a.active i,.sidebar-nav li a:hover i{opacity:1}
.sidebar-cta{background:var(--ink);color:#fff;border:0;text-align:center}
.sidebar-cta h4{color:#fff;border-bottom-color:rgba(255,255,255,.3)}
.sidebar-cta p{color:rgba(255,255,255,.75);margin-bottom:16px;font-size:.9rem}
.sidebar-stamp{display:flex;justify-content:center;margin-bottom:10px}
.sidebar-stamp img{width:80px;height:80px;filter:invert(1) sepia(1) saturate(5) hue-rotate(-20deg)}
.sidebar-contact-list li{display:flex;gap:10px;align-items:flex-start;padding:8px 0;font-size:.88rem;color:var(--ink-soft)}
.sidebar-contact-list li i{color:var(--red);margin-top:3px;width:16px}

@media(max-width:960px){
  .service-detail-grid{grid-template-columns:1fr}
  .service-sidebar{position:static}
  .service-detail-content{padding:28px 22px}
  .service-detail-img{margin:-28px -22px 22px}
}

/* ---------- 18. USLUGI PAGE (archive grid) ---------- */

.archive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:1080px;margin:0 auto}
.archive-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s}
.archive-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.archive-img{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2);position:relative}
.archive-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.archive-card:hover .archive-img img{transform:scale(1.05)}
.archive-num{position:absolute;top:14px;left:14px;background:var(--ink);color:#fff;font-family:var(--font-mono);font-size:.78rem;font-weight:700;padding:6px 10px;letter-spacing:.1em;border-radius:2px}
.archive-body{padding:22px}
.archive-body h3{font-size:1.2rem;margin-bottom:8px}
.archive-body h3 a{color:var(--ink)}
.archive-body h3 a:hover{color:var(--red)}
.archive-body p{font-size:.92rem;color:var(--ink-muted);margin-bottom:12px;line-height:1.55}
.archive-cta{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-weight:600;font-size:.9rem}
.archive-cta i{transition:transform .2s}
.archive-card:hover .archive-cta i{transform:translateX(5px)}

/* ---------- 19. FAQ ---------- */

.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.faq-item.active{border-color:var(--red)}
.faq-question{display:flex;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:20px 24px;font-family:var(--font-serif);font-size:1.08rem;font-weight:700;text-align:left;transition:color .15s}
.faq-question i{transition:transform .3s;color:var(--red)}
.faq-item.active .faq-question{color:var(--red)}
.faq-item.active .faq-question i{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}
.faq-answer-inner{padding:0 24px 22px;color:var(--ink-soft);font-size:.98rem;line-height:1.65}
.faq-answer-inner a{color:var(--red);font-weight:600;border-bottom:1px dashed var(--red)}

/* ---------- 20. UTIL / ANIM ---------- */

/* Honeypot anti-spam field — visually hidden, accessible */
.honeypot-trap{position:absolute!important;top:-9999px!important;left:-9999px!important;width:0!important;height:0!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important;z-index:-1!important;visibility:hidden!important}

/* Service page CTA button wrapper */
.service-cta-wrap{margin-top:26px}

/* Google Maps embed wrapper */
.map-embed-wrap{margin-top:28px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;box-shadow:var(--shadow)}
.map-embed-wrap iframe{width:100%;height:100%;border:0;display:block}

/* Centered narrow form (FAQ page) */
.contact-form-centered{max-width:720px;margin:0 auto}

/* FAQ initially-active answer (CSS fallback, JS overrides for animation) */
.faq-item.active .faq-answer{max-height:600px}

.reveal{opacity:0;transform:translateY(24px);transition:all .7s cubic-bezier(.2,.7,.2,1)}
.reveal-left{opacity:0;transform:translateX(-24px);transition:all .7s cubic-bezier(.2,.7,.2,1)}
.reveal-right{opacity:0;transform:translateX(24px);transition:all .7s cubic-bezier(.2,.7,.2,1)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none}

.scroll-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--ink);color:#fff;z-index:40;opacity:0;visibility:hidden;transition:.25s;box-shadow:var(--shadow-lg)}
.scroll-top.visible{opacity:1;visibility:visible}
.scroll-top:hover{background:var(--red)}

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