/* =============================================================
   Memorial · Pompe Funebre Craiova
   Design system — warm editorial, EB Garamond + Inter
   Modular typographic scale: ratio 1.333 (major third)
   ============================================================= */

:root{
  /* ---- Colour ---- */
  --paper:        #FBF8F2;   /* warm ivory page background */
  --paper-2:      #F4EDDF;   /* deeper cream section */
  --paper-3:      #EDE4D2;   /* card / inset */
  --ink:          #211C16;   /* warm near-black */
  --ink-soft:     #514941;   /* muted body */
  --ink-faint:    #6B6257;   /* meta / captions (darkened for WCAG AA) */
  --gold:         #A67C3D;   /* antique gold accent */
  --gold-deep:    #8A6430;  /* AA-compliant on paper-2 (4.57:1) */
  --gold-soft:    #D8C49A;
  --sage:         #6E7A6A;   /* secondary calm green */
  --line:         rgba(33,28,22,.12);
  --line-2:       rgba(33,28,22,.07);
  --dark:         #1B1712;   /* dark contrast section */
  --dark-2:       #241F18;
  --on-dark:      #F2EADA;
  --on-dark-soft: #C5BAA6;

  /* ---- Type scale (base 16px · 1.333) ---- */
  --fs--1: 0.7506rem;   /* 12   */
  --fs-0:  1rem;        /* 16   */
  --fs-1:  1.333rem;    /* 21.3 */
  --fs-2:  1.7769rem;   /* 28.4 */
  --fs-3:  2.3686rem;   /* 37.9 */
  --fs-4:  3.1573rem;   /* 50.5 */
  --fs-5:  4.2087rem;   /* 67.3 */

  --serif: "EB Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* ---- Rhythm ---- */
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --maxw: 1440px;
  --maxw-narrow: 760px;
  --radius: 3px;
  --shadow: 0 1px 2px rgba(33,28,22,.05), 0 18px 48px -28px rgba(33,28,22,.35);
  --shadow-soft: 0 1px 30px -18px rgba(33,28,22,.4);
  --ease: cubic-bezier(.2,.6,.2,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{font-size:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (max-width:600px){html{font-size:100%}}
body{
  font-family:var(--sans);
  font-size:var(--fs-0);
  line-height:1.65;
  color:var(--ink-soft);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;

}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* ---- Typography ---- */
h1,h2,h3,h4{
  font-family:var(--serif);
  color:var(--ink);
  font-weight:500;
  line-height:1.08;
  letter-spacing:-.01em;
}
h1{font-size:clamp(2.4rem,6vw,var(--fs-5));line-height:1.02;font-weight:500}
h2{font-size:clamp(2rem,4.4vw,var(--fs-4));margin-bottom:.4em}
h3{font-size:var(--fs-2)}
h4{font-size:var(--fs-1);line-height:1.2}
p{max-width:68ch}
strong{color:var(--ink);font-weight:600}

.eyebrow{
  font-family:var(--sans);
  font-size:var(--fs--1);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:1.8rem;height:1px;background:var(--gold);display:inline-block;
}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:1.8rem;height:1px;background:var(--gold)}

.lead{font-size:var(--fs-1);line-height:1.5;color:var(--ink-soft);font-weight:400}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.narrow{max-width:var(--maxw-narrow);margin-inline:auto;padding-inline:var(--gutter)}
section{padding-block:clamp(3.5rem,8vw,6.5rem)}
.center{text-align:center}
.section-head{max-width:62ch}
.section-head.center{margin-inline:auto}
.section-head h2{margin-top:.5rem}

/* =============================================================
   Skip link + accessibility
   ============================================================= */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:.5rem;top:.5rem}
:focus{outline:2px solid var(--gold-deep);outline-offset:3px}
:focus:not(:focus-visible){outline:none}

/* =============================================================
   Top utility bar
   ============================================================= */
.topbar{
  background:var(--dark);color:var(--on-dark-soft);
  font-size:var(--fs--1);letter-spacing:.02em;
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:42px;padding-block:.35rem}
.topbar a{color:var(--on-dark);transition:color .2s}
.topbar a:hover{color:var(--gold-soft)}
.topbar .nonstop{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--on-dark)}
.dot{position:relative;width:8px;height:8px;border-radius:50%;background:#7FB37A}
.dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#7FB37A;animation:pulse 2.4s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(3.2);opacity:0}100%{transform:scale(3.2);opacity:0}}
.preload *,.preload *::before,.preload *::after{transition:none!important;animation:none!important}
.topbar .tb-right{display:flex;gap:1.4rem;align-items:center}
@media (max-width:760px){.topbar .tb-right span.hide{display:none}}

/* =============================================================
   Header
   ============================================================= */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,248,242,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:56px;width:auto}
.brand .bt{font-family:var(--serif);font-size:1.32rem;color:var(--ink);line-height:1;font-weight:600;letter-spacing:.01em}
.brand .bs{display:block;font-family:var(--sans);font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-top:0}

.nav{display:flex;align-items:center;gap:2.1rem}
.nav a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;padding-block:.4rem;transition:color .2s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--gold);transition:width .28s var(--ease)}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav a.active{color:var(--gold-deep)}

.btn{
  display:inline-flex;align-items:center;gap:.6em;justify-content:center;
  font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.01em;
  padding:.85em 1.5em;border-radius:var(--radius);transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--on-dark)}
.btn-primary:hover{background:var(--gold-deep);transform:translateY(-1px)}
.btn-gold{background:var(--gold-deep);color:#fff}
.btn-gold:hover{background:var(--gold);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-deep)}
.btn-ondark{background:var(--gold-deep);color:#fff}
.btn-ondark:hover{background:#fff;color:var(--ink)}
.btn-lg{padding:1.05em 1.9em;font-size:.98rem}

.header-cta{display:flex;align-items:center;gap:1rem}
.header-phone{display:inline-flex;flex-direction:column;align-items:flex-end;line-height:1.1;padding-block:.3rem}
.header-phone .lbl{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;white-space:nowrap}
.header-phone .num{font-family:var(--serif);font-size:1.32rem;color:var(--ink);font-weight:600;white-space:nowrap}
.header-phone .num:hover{color:var(--gold-deep)}

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

@media (max-width:980px){
  .nav{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:0 var(--gutter);
    max-height:0;overflow:hidden;visibility:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease),visibility .4s}
  .nav.open{max-height:60vh;padding-block:1rem;visibility:visible}
  .nav a{width:100%;padding:.9rem 0;border-bottom:1px solid var(--line-2);font-size:1.05rem}
  .header-phone,.header-cta .btn{display:none}
  .burger{display:flex}
}

/* =============================================================
   Hero
   ============================================================= */
.hero{position:relative;background:var(--dark);color:var(--on-dark);overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(rgba(27,23,18,.25), rgba(27,23,18,.45));
}
.hero .wrap{position:relative;z-index:2;padding-block:clamp(2rem,4vw,3.5rem);display:grid;gap:1.7rem;max-width:var(--maxw)}
.hero-inner{width:65%}
@media (max-width:760px){.hero-inner{width:100%}}
.hero h1{color:#fff;font-weight:500;margin-bottom:32px}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .lead{color:var(--on-dark-soft);max-width:48ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.4rem}
@media (max-width:600px){.hero-actions{flex-direction:column;align-items:stretch}.hero-actions .btn{width:100%}}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem;margin-top:1.4rem;padding-top:1.6rem;border-top:1px solid rgba(242,234,218,.16)}
.hero-trust .ht{display:flex;flex-direction:column}
.hero-trust .ht b{font-family:var(--serif);font-size:var(--fs-2);color:#fff;line-height:1;font-weight:600}
.hero-trust .ht span{font-size:var(--fs--1);letter-spacing:.04em;color:var(--on-dark-soft);margin-top:.4em}

/* reveal animation */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-d="1"]{transition-delay:.08s}
[data-reveal-d="2"]{transition-delay:.16s}
[data-reveal-d="3"]{transition-delay:.24s}
[data-reveal-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}.dot::after{animation:none}}

/* =============================================================
   Services grid
   ============================================================= */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
@media (max-width:900px){.services{grid-template-columns:1fr}}
.scard{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2.1rem 1.9rem;display:flex;flex-direction:column;gap:1rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  overflow:hidden;
}
.scard::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width .4s var(--ease)}
.scard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.scard:hover::before{width:100%}
.scard .scard-img{display:block;width:calc(100% + 3.8rem);max-width:none;margin:-2.1rem -1.9rem 1rem -1.9rem;height:220px;object-fit:cover}
.scard .ico{width:48px;height:48px;color:var(--gold-deep)}
.scard h3{font-size:var(--fs-1);color:var(--ink)}
.scard p{font-size:.96rem;color:var(--ink-soft);flex:1}
.scard .more{font-size:.86rem;font-weight:600;letter-spacing:.02em;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.5em;margin-top:.3rem}
.scard .more svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.scard:hover .more svg{transform:translateX(4px)}

/* =============================================================
   Split / about
   ============================================================= */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr}}
.split.alt .split-media{order:-1}
@media (max-width:900px){.split.alt .split-media{order:0}}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--paper-2);min-height:380px;border:1px solid var(--line)}
.split-media svg{width:100%;height:100%}
.split-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split-media .badge{position:absolute;left:1.4rem;bottom:1.4rem;background:var(--ink);color:var(--on-dark);padding:.9rem 1.2rem;border-radius:var(--radius);font-family:var(--serif)}
.split-media .badge b{display:block;font-size:var(--fs-2);line-height:1;color:#fff;font-weight:600}
.split-media .badge span{font-size:var(--fs--1);font-family:var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft)}

.feature-list{display:grid;gap:1.1rem;margin-top:1.6rem}
.feature-list li{display:flex;gap:.9rem;align-items:flex-start}
.feature-list .fi{flex:none;width:30px;height:30px;border-radius:50%;background:var(--paper-3);color:var(--gold-deep);display:grid;place-items:center;margin-top:.15rem}
.feature-list .fi svg{width:16px;height:16px}
.feature-list b{color:var(--ink);font-size:1.02rem}
.feature-list p{font-size:.94rem;margin-top:.15rem}

/* =============================================================
   Dark section / steps
   ============================================================= */
.dark-sec{background:var(--dark);color:var(--on-dark)}
.dark-sec h2,.dark-sec h3{color:#fff}
.dark-sec .lead{color:var(--on-dark-soft)}
.dark-sec .eyebrow{color:var(--gold-soft)}
.dark-sec .eyebrow::before,.dark-sec .eyebrow.center::after{background:var(--gold)}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.6rem;counter-reset:step}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:1.7rem 1.4rem;background:var(--dark-2);border:1px solid rgba(242,234,218,.1);border-radius:var(--radius)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);font-size:var(--fs-2);color:var(--gold);display:block;margin-bottom:.6rem;font-weight:600}
.step h3{color:#fff;font-size:1.12rem;margin-bottom:.4rem}
.step p{color:var(--on-dark-soft);font-size:.92rem}

/* =============================================================
   Stats band
   ============================================================= */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr}}
.stat b{display:block;font-family:var(--serif);font-size:clamp(2.4rem,5vw,var(--fs-4));color:var(--gold-deep);line-height:1;font-weight:600}
.stat span{display:block;font-size:.9rem;color:var(--ink-soft);margin-top:.6rem;letter-spacing:.02em}

/* =============================================================
   FAQ
   ============================================================= */
.faq{max-width:820px;margin-inline:auto;margin-top:2.4rem;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:1.25rem 2.6rem 1.25rem 0;position:relative;
  font-family:var(--serif);font-size:1.22rem;color:var(--ink);font-weight:500;transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--gold-deep)}
.faq summary::after{content:"+";position:absolute;right:.2rem;top:1.1rem;font-family:var(--sans);font-size:1.5rem;color:var(--gold-deep);transition:transform .3s var(--ease);line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 2.6rem 1.4rem 0}
.faq .ans p{font-size:.98rem}
.faq .ans p+p{margin-top:.8rem}

/* =============================================================
   Areas / GEO chips
   ============================================================= */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.chip{font-size:.86rem;padding:.7em 1em;border:1px solid var(--line);border-radius:100px;color:var(--ink-soft);background:#fff;transition:.2s}
.chip:hover{border-color:var(--gold);color:var(--gold-deep)}

/* =============================================================
   CTA band
   ============================================================= */
.cta{background:linear-gradient(135deg,var(--gold-deep),var(--gold));color:#fff;text-align:center}
.cta h2{color:#fff}
.cta p{color:rgba(255,255,255,.9);margin-inline:auto}
.cta .cta-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.8rem}
.hero .btn-primary{background:#fff;color:var(--ink)}
.hero .btn-primary:hover{background:var(--gold-deep);color:#fff}
.cta .btn-primary{background:#fff;color:var(--ink)}
.cta .btn-primary:hover{background:var(--ink);color:#fff}
.cta .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.cta .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}

/* =============================================================
   Generic prose (service & legal pages)
   ============================================================= */
.prose{max-width:none}
.prose-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
.prose h2{margin-top:0}
.prose h3{font-size:var(--fs-1);color:var(--ink);margin:2.2rem 0 .7rem}
.prose p{margin-bottom:1.05rem;max-width:72ch}
ul.ticks{display:grid;gap:.7rem;margin:1.2rem 0}
ul.ticks li{position:relative;padding-left:1.9rem;color:var(--ink-soft)}
ul.ticks li::before{content:"";position:absolute;left:0;top:.45em;width:1.1rem;height:1.1rem;border-radius:50%;
  background:var(--paper-3);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A6430' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:.7rem;background-repeat:no-repeat;background-position:center}
ul.ticks li b{color:var(--ink)}

/* sidebar layout for service pages */
.svc-layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,5vw,4rem);align-items:start}
@media (max-width:980px){.svc-layout{grid-template-columns:1fr}}
.svc-aside{position:sticky;top:96px;display:grid;gap:1.2rem}
.aside-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.aside-card.dark{background:var(--dark);color:var(--on-dark)}
.aside-card.dark h4,.aside-card.dark .num{color:#fff}
.aside-card h4{font-size:1.2rem;margin-bottom:.5rem}
.aside-card p{font-size:.92rem;margin-bottom:1rem}
.aside-card .num{font-family:var(--serif);font-size:var(--fs-2);font-weight:600;color:var(--ink);display:block;line-height:1.1}
.aside-card.dark .num{color:#fff}
.aside-card .num:hover{color:var(--gold-soft)}
.aside-nav a{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.85rem 0;border-bottom:1px solid var(--line-2);font-size:.94rem;color:var(--ink);transition:.2s}
.aside-nav a:last-child{border-bottom:0}
.aside-nav a:hover{color:var(--gold-deep);padding-left:.3rem}
.aside-nav a svg{width:15px;height:15px;color:var(--gold-deep)}

/* page hero (interior) */
.page-hero{background:var(--paper-2);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-3%;top:-30%;width:380px;height:380px;
  background:radial-gradient(circle,rgba(166,124,61,.12),transparent 70%);pointer-events:none}
.page-hero .wrap{padding-block:clamp(2.6rem,6vw,4.4rem);position:relative;z-index:1}
@media (min-width:761px){.page-hero .wrap{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}}
.hero-img{width:100%;height:clamp(220px,20vw,320px);object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.section-video{width:100%;max-width:800px;display:block;margin:2rem auto;border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:16/9;object-fit:cover}
.crumbs{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.82rem;color:var(--ink-faint);margin-bottom:1.1rem}
.crumbs a:hover{color:var(--gold-deep)}
.crumbs span.sep{opacity:.5}
.page-hero h1{font-size:clamp(2.2rem,5vw,var(--fs-4));max-width:18ch}
.page-hero .lead{margin-top:1rem;max-width:60ch}

/* related links */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem}
@media (max-width:760px){.related{grid-template-columns:1fr}}
.rcard{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:.25s var(--ease)}
.rcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.rcard-img{display:block;width:calc(100% + 3rem);max-width:none;margin:-1.5rem -1.5rem .6rem -1.5rem;height:160px;object-fit:cover;border-radius:0}
.rcard-logo{display:block;width:auto;max-height:80px;margin:0 auto .6rem;object-fit:contain}
.rcard .k{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.rcard h4{font-size:1.16rem}
.rcard-ttl{font-family:var(--serif);font-size:1.16rem;font-weight:500;line-height:1.2;letter-spacing:-.01em;color:var(--ink);display:block}
.rcard p{font-size:.9rem}

/* info table */
.itable{width:100%;border-collapse:collapse;margin:1.4rem 0;font-size:.95rem}
.itable th,.itable td{text-align:left;padding:.85rem 1rem;border-bottom:1px solid var(--line)}
.itable th{font-family:var(--sans);font-weight:600;color:var(--ink);background:var(--paper-2);font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.itable td b{color:var(--ink)}
.itable tr:hover td{background:var(--paper-2)}

/* callout */
.callout{background:var(--paper-2);border-left:3px solid var(--gold);border-radius:var(--radius);padding:1.4rem 1.6rem;margin:1.6rem 0}
.callout p{margin-bottom:0;font-size:.96rem}
.callout b{color:var(--ink)}

/* =============================================================
   Contact
   ============================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem)}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-info .ci{display:flex;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--line)}
.contact-info .ci:first-child{padding-top:0}
.contact-info .ci .ico{flex:none;width:42px;height:42px;border-radius:50%;background:var(--paper-2);color:var(--gold-deep);display:grid;place-items:center}
.contact-info .ci .ico svg{width:20px;height:20px}
.contact-info .ci .k{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;display:block}
.contact-info .ci .v{font-size:1.1rem;color:var(--ink);font-family:var(--serif);display:block}
.contact-info .ci .v a:hover{color:var(--gold-deep)}

.cform{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,4vw,2.4rem)}
.cform .field{margin-bottom:1.1rem}
.cform label{display:block;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.4rem;letter-spacing:.02em}
.cform input,.cform textarea,.cform select{
  width:100%;font-family:var(--sans);font-size:.98rem;color:var(--ink);
  padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);transition:border-color .2s,box-shadow .2s}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(166,124,61,.45)}
.cform textarea{resize:vertical;min-height:130px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:520px){.cform .row{grid-template-columns:1fr}}
.cform .btn{width:100%;margin-top:.4rem}
.form-note{font-size:.82rem;color:var(--ink-faint);margin-top:.9rem;text-align:center}
.form-status{margin-top:1rem;padding:.9rem 1rem;border-radius:var(--radius);font-size:.92rem;display:none}
.form-status.ok{display:block;background:#E8F0E5;color:#3C5A37;border:1px solid #BFD4B8}
.form-status.err{display:block;background:#F6E4E0;color:#7A3B2E;border:1px solid #E0BCB2}
.field-err{font-size:.78rem;color:#7A3B2E;margin-top:.35rem}

.map-embed{margin-top:2.4rem;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;line-height:0}
.map-embed iframe{width:100%;height:420px;border:0;filter:grayscale(.25) contrast(1.02)}

/* =============================================================
   Footer
   ============================================================= */
.site-footer{background:var(--dark);color:var(--on-dark-soft);padding-block:clamp(3rem,6vw,4.5rem) 1.5rem}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
@media (max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.footer-top{grid-template-columns:1fr}}
.site-footer h3{font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.2rem;font-weight:600}
.site-footer .fbrand .bt{font-family:var(--serif);font-size:1.4rem;color:#fff;font-weight:600}
.site-footer .fbrand .bs{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;display:block;margin-top:.3em}
.site-footer .fbrand p{font-size:.92rem;margin-top:1rem;color:var(--on-dark-soft)}
.footer-links a,.footer-contact a{display:block;padding:.7rem 0;font-size:.94rem;color:var(--on-dark-soft);transition:color .2s}
.footer-links a:hover,.footer-contact a:hover{color:var(--gold-soft)}
.footer-contact .lbl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-soft);margin-top:.9rem}
.footer-contact .big{font-family:var(--serif);font-size:1.3rem;color:#fff}
.footer-nonstop{display:inline-flex;align-items:center;gap:.5em;margin-top:1.2rem;font-size:.84rem;color:var(--on-dark);background:rgba(242,234,218,.06);padding:.5em 1em;border-radius:100px}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(242,234,218,.12);font-size:.82rem;color:var(--on-dark-soft)}
.footer-bottom a:hover{color:var(--gold-soft)}
.footer-bottom .fb-links{display:flex;gap:1.4rem;flex-wrap:wrap}

/* =============================================================
   Floating call (mobile)
   ============================================================= */
.fab{position:fixed;right:1rem;bottom:1rem;z-index:90;display:none;gap:.7rem}
.fab a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);color:#fff}
.fab .call{background:var(--gold-deep)}
.fab .wa{background:#25D366}
.fab a svg{width:24px;height:24px}
@media (max-width:980px){.fab{display:flex}}

/* utility */
.mt-0{margin-top:0}
.muted{color:var(--ink-faint)}
hr.rule{border:0;height:1px;background:var(--line);margin:2.4rem 0}
.tag{display:inline-block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;background:var(--paper-2);padding:.4em .9em;border-radius:100px;border:1px solid var(--line)}

@media print{
  body{font-size:12pt;color:#000;background:#fff}
  .skip,.fab,.topbar,.site-header,.site-footer,.hero-actions,.hero-trust,.cta-actions,.aside-nav{display:none!important}
  .hero{min-height:0;padding:1cm 0;background:#fff!important;color:#000}
  .hero::before{display:none}
  .hero h1{color:#000}
  .hero .lead{color:#333}
  .page-hero::after{display:none}
  .split-media{border:1px solid #ccc;break-inside:avoid}
  .scard,.rcard,.aside-card,.cform{border:1px solid #ccc;break-inside:avoid}
  .wrap{max-width:100%}
  a[href]{color:#000;text-decoration:underline}
  a[href^="tel:"]::after,.fab a[href*="wa.me"]::after{content:" (" attr(href) ")";font-size:.8em}
  img{max-width:100%!important;page-break-inside:avoid}
  .map-embed iframe{height:250px;filter:none}
}
