/* ============================================================
   Foto-Celina — Piotr Pieklik · Studio Fotografii (Sandomierz)
   Editorial photo-first, warm gallery. Cormorant + Jost.
   Mobile-first, WCAG AA.
   ============================================================ */

/* ---------- Fonts (self-hosted woff2) ---------- */
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-500-latin-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-500-latin.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-600-latin-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-600-latin.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-700-latin-ext.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Cormorant";src:url("assets/fonts/cormorant-700-latin.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

@font-face{font-family:"Jost";src:url("assets/fonts/jost-400-latin-ext.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Jost";src:url("assets/fonts/jost-400-latin.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Jost";src:url("assets/fonts/jost-500-latin-ext.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Jost";src:url("assets/fonts/jost-500-latin.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Jost";src:url("assets/fonts/jost-600-latin-ext.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Jost";src:url("assets/fonts/jost-600-latin.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ---------- Tokens ---------- */
:root{
  --paper:#F7F3EE;        /* warm ivory bg */
  --paper-2:#EFE8E0;      /* secondary surface */
  --paper-3:#E7DECF;      /* tertiary / cards on paper */
  --ink:#2A2622;          /* primary text ~11:1 on paper */
  --ink-deep:#221F1C;     /* dark sections */
  --ink-2:#3B3631;
  --muted:#6E655C;        /* secondary text ~4.7:1 on paper */
  --rose:#B5798A;         /* decorative rose accent */
  --rose-ink:#8A4F60;     /* rose as text (>=4.5:1 on paper) */
  --brass:#9C7A3C;        /* brass accent line */
  --brass-ink:#6F5526;    /* brass as text (>=4.5:1 on paper) */
  --line:#DED5C9;         /* hairline */
  --line-2:#CDBFAD;
  --on-deep:#F4EEE6;      /* text on dark ~13:1 */
  --on-deep-mut:#C3B8AC;  /* muted text on dark ~5.5:1 */
  --gold-deep:#D8B271;    /* brass on dark (>=4.5:1) */
  --rose-deep:#E0A6B4;    /* rose on dark (>=4.5:1) */

  --maxw:1200px;
  --gutter:clamp(1.15rem,5vw,2.5rem);
  --radius:3px;
  --radius-lg:6px;
  --shadow:0 1px 2px rgba(34,31,28,.05),0 8px 28px rgba(34,31,28,.07);
  --shadow-lg:0 14px 50px rgba(34,31,28,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.28s;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:"Jost",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:clamp(1rem,.97rem + .15vw,1.075rem);
  line-height:1.7;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
button{font:inherit;color:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;font-family:"Cormorant",Georgia,"Times New Roman",serif;font-weight:600;line-height:1.06;letter-spacing:-.01em;color:var(--ink)}
p{margin:0 0 1rem}
:focus-visible{outline:2.5px solid var(--rose-ink);outline-offset:3px;border-radius:2px}
::selection{background:var(--rose);color:#fff}
.tnum{font-variant-numeric:tabular-nums}

/* ---------- Skip link ---------- */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink-deep);color:var(--on-deep);padding:.7rem 1.1rem;border-radius:0 0 6px 0;font-weight:500}
.skip:focus{left:0}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap--narrow{max-width:780px}
.section{padding-block:clamp(3.4rem,8vw,6.5rem)}
.section--tight{padding-block:clamp(2.6rem,6vw,4.5rem)}
.section--paper2{background:var(--paper-2)}
.section--deep{background:var(--ink-deep);color:var(--on-deep)}
.section--deep h1,.section--deep h2,.section--deep h3{color:var(--on-deep)}

.eyebrow{
  font-family:"Jost",sans-serif;font-weight:500;font-size:.74rem;
  letter-spacing:.26em;text-transform:uppercase;color:var(--brass-ink);
  margin:0 0 1rem;display:flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--brass);flex:none}
.section--deep .eyebrow{color:var(--gold-deep)}
.section--deep .eyebrow::before{background:var(--gold-deep)}
.center .eyebrow{justify-content:center}

.h-display{font-size:clamp(2.4rem,7vw,4.6rem)}
.h-1{font-size:clamp(2rem,5.5vw,3.4rem)}
.h-2{font-size:clamp(1.6rem,4vw,2.4rem)}
.h-3{font-size:clamp(1.3rem,2.6vw,1.7rem);font-weight:600}
.lead{font-size:clamp(1.08rem,1rem + .55vw,1.32rem);color:var(--ink-2);line-height:1.65;max-width:56ch}
.muted{color:var(--muted)}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:"Jost",sans-serif;font-weight:500;font-size:.95rem;letter-spacing:.02em;
  padding:.95rem 1.7rem;border-radius:var(--radius);border:1px solid transparent;
  white-space:nowrap;cursor:pointer;transition:background var(--t),color var(--t),border-color var(--t),transform var(--t);
  min-height:48px;
}
.btn .ico{width:1.15em;height:1.15em;flex:none}
.btn--primary{background:var(--ink-deep);color:var(--on-deep);border-color:var(--ink-deep)}
.btn--primary:hover{background:var(--rose-ink);border-color:var(--rose-ink);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--on-deep)}
.btn--light{background:var(--paper);color:var(--ink-deep);border-color:var(--paper)}
.btn--light:hover{background:var(--rose-deep);border-color:var(--rose-deep);color:var(--ink-deep)}
.btn--outline-light{background:transparent;color:var(--on-deep);border-color:rgba(244,238,230,.45)}
.btn--outline-light:hover{border-color:var(--on-deep);background:rgba(244,238,230,.1)}
.btn:active{transform:translateY(1px)}
.btn--lg{padding:1.1rem 2rem;font-size:1rem}

.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;color:var(--ink);border-bottom:1px solid var(--line-2);padding-bottom:3px;transition:gap var(--t),border-color var(--t),color var(--t)}
.link-arrow .ico{width:1.05em;height:1.05em;transition:transform var(--t)}
.link-arrow:hover{gap:.8rem;border-color:var(--ink)}
.link-arrow:hover .ico{transform:translateX(3px)}
.section--deep .link-arrow{color:var(--on-deep);border-color:rgba(244,238,230,.35)}
.section--deep .link-arrow:hover{border-color:var(--on-deep)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,243,238,.9);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:68px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:"Cormorant",serif;line-height:1}
.brand__mark{width:34px;height:34px;flex:none}
.brand__txt{display:flex;flex-direction:column}
.brand__name{font-size:1.32rem;font-weight:700;letter-spacing:.01em}
.brand__sub{font-family:"Jost",sans-serif;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:500}

.nav{display:none}
.nav ul{display:flex;align-items:center;gap:.3rem}
.nav a{display:inline-block;padding:.55rem .85rem;font-size:.92rem;font-weight:400;color:var(--ink-2);white-space:nowrap;border-radius:2px;transition:color var(--t),background var(--t);position:relative}
.nav a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.36rem;height:1px;background:var(--rose-ink);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--ink);font-weight:500}
.nav a[aria-current="page"]::after{transform:scaleX(1);background:var(--brass)}

.header-cta{display:flex;align-items:center;gap:.6rem}
.tel-link{display:none;align-items:center;gap:.5rem;font-weight:500;font-size:.95rem;color:var(--ink);white-space:nowrap}
.tel-link .ico{width:1.05em;height:1.05em;color:var(--rose-ink)}
.tel-link:hover{color:var(--rose-ink)}

.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--line-2);border-radius:3px;background:transparent;padding:0 11px}
.burger span{height:1.6px;background:var(--ink);border-radius:2px;transition:transform var(--t),opacity var(--t)}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* Mobile nav panel */
.mobile-nav{position:fixed;inset:0 0 0 auto;z-index:99;width:min(86vw,360px);background:var(--paper);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .36s var(--ease);display:flex;flex-direction:column;padding:5.2rem var(--gutter) 2rem;overflow-y:auto;box-shadow:var(--shadow-lg)}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav ul{display:flex;flex-direction:column;gap:.2rem;border-top:1px solid var(--line)}
.mobile-nav li{border-bottom:1px solid var(--line)}
.mobile-nav a{display:block;padding:1rem .2rem;font-family:"Cormorant",serif;font-size:1.55rem;font-weight:600;color:var(--ink)}
.mobile-nav a[aria-current="page"]{color:var(--rose-ink)}
.mobile-nav__foot{margin-top:auto;padding-top:1.6rem;display:flex;flex-direction:column;gap:.7rem}
.mobile-nav__foot a{font-weight:500}
.mobile-nav__foot .ico{width:1.05em;height:1.05em;color:var(--rose-ink);vertical-align:-.18em;margin-right:.4rem}
.scrim{position:fixed;inset:0;z-index:98;background:rgba(34,31,28,.46);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.scrim.open{opacity:1;visibility:visible}
body.nav-open{overflow:hidden}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink-deep);color:var(--on-deep);overflow:hidden}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,22,.52) 0%,rgba(28,25,22,.28) 40%,rgba(28,25,22,.74) 100%)}
.hero__inner{position:relative;z-index:2;padding-block:clamp(5rem,17vh,8.5rem);max-width:740px}
.hero h1{color:var(--on-deep);font-weight:600;margin:.4rem 0 1.2rem;text-shadow:0 2px 24px rgba(0,0,0,.32)}
.hero .eyebrow{color:#F1C98A;text-shadow:0 1px 10px rgba(0,0,0,.55)}
.hero .eyebrow::before{background:#F1C98A}
.hero__lead{color:#F2EBE1;font-size:clamp(1.08rem,1rem + .5vw,1.3rem);max-width:48ch;text-shadow:0 1px 14px rgba(0,0,0,.3)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:2.4rem;padding-top:1.7rem;border-top:1px solid rgba(244,238,230,.2)}
.hero__meta .m{display:flex;flex-direction:column;gap:.1rem}
.hero__meta .m b{font-family:"Cormorant",serif;font-size:1.85rem;font-weight:600;color:var(--gold-deep);line-height:1}
.hero__meta .m span{font-size:.78rem;letter-spacing:.06em;color:var(--on-deep-mut);text-transform:uppercase}

/* ---------- Trust strip ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.trust__row{display:flex;flex-wrap:wrap;gap:.7rem 1.3rem;align-items:center;justify-content:center;padding-block:1.1rem;text-align:center}
.trust__row .pill{display:inline-flex;align-items:center;gap:.5rem;font-size:.86rem;color:var(--ink-2);font-weight:400}
.trust__row .pill .ico{width:1.05em;height:1.05em;color:var(--rose-ink);flex:none}
.trust__row .sep{width:1px;height:16px;background:var(--line-2);display:none}

/* ---------- Generic grid ---------- */
.grid{display:grid;gap:clamp(1rem,3vw,1.8rem)}
.split{display:grid;gap:clamp(1.6rem,5vw,3.5rem);align-items:center}

/* ---------- Figure / frame ---------- */
.frame{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--paper-3)}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.frame--portrait{aspect-ratio:4/5}
.frame--tall{aspect-ratio:3/4}
.frame:hover img{transform:scale(1.04)}
.frame__tag{position:absolute;left:0;bottom:0;background:rgba(34,31,28,.78);color:var(--on-deep);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:.45rem .8rem;backdrop-filter:blur(2px)}

/* ---------- Intro / philosophy split ---------- */
.intro__media{position:relative}
.intro__media .frame{box-shadow:var(--shadow-lg)}
.intro__media .badge{position:absolute;right:-12px;bottom:-18px;background:var(--paper);border:1px solid var(--line);border-radius:50%;width:120px;height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--shadow);transform:rotate(-7deg)}
.intro__media .badge b{font-family:"Cormorant",serif;font-size:2rem;font-weight:700;line-height:1;color:var(--rose-ink)}
.intro__media .badge span{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}

/* ---------- Service cards ---------- */
.svc-grid{grid-template-columns:1fr}
.svc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.7rem;transition:border-color var(--t),box-shadow var(--t),transform var(--t)}
.svc:hover{border-color:var(--line-2);box-shadow:var(--shadow);transform:translateY(-3px)}
.svc__ico{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--paper-2);border:1px solid var(--line);margin-bottom:1.1rem}
.svc__ico .ico{width:20px;height:20px;color:var(--rose-ink)}
.svc h3{font-size:1.4rem;margin-bottom:.5rem}
.svc p{color:var(--muted);font-size:.96rem;margin-bottom:1rem}
.svc ul.ticks{display:flex;flex-direction:column;gap:.45rem;margin:0 0 .4rem}
.ticks li{display:flex;gap:.55rem;align-items:flex-start;font-size:.92rem;color:var(--ink-2)}
.ticks .ico{width:1.05em;height:1.05em;color:var(--brass-ink);flex:none;margin-top:.28em}

/* ---------- Offer rows (detailed) ---------- */
.offer{display:grid;gap:clamp(1.4rem,4vw,2.6rem);align-items:center;padding-block:clamp(2rem,5vw,3rem);border-top:1px solid var(--line)}
.offer:first-of-type{border-top:0}
.offer__num{font-family:"Cormorant",serif;font-size:1rem;color:var(--brass-ink);letter-spacing:.1em}
.offer h3{font-size:clamp(1.6rem,3.4vw,2.1rem);margin:.3rem 0 .8rem}
.offer .frame{box-shadow:var(--shadow)}
.price-note{display:inline-flex;align-items:center;gap:.5rem;margin-top:.6rem;font-size:.86rem;color:var(--brass-ink);font-weight:500;letter-spacing:.02em}
.price-note .ico{width:1.05em;height:1.05em}

/* ---------- Portfolio gallery ---------- */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2.2rem}
.filter{padding:.55rem 1.1rem;border:1px solid var(--line-2);border-radius:999px;background:transparent;font-size:.86rem;font-weight:500;color:var(--ink-2);letter-spacing:.02em;transition:all var(--t)}
.filter:hover{border-color:var(--ink);color:var(--ink)}
.filter[aria-pressed="true"]{background:var(--ink-deep);border-color:var(--ink-deep);color:var(--on-deep)}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.gallery .frame{aspect-ratio:4/5}
.gallery .frame__tag{opacity:0;transition:opacity var(--t)}
.gallery .frame:hover .frame__tag,.gallery .frame:focus-within .frame__tag{opacity:1}
.gitem.hide{display:none}

/* ---------- Process steps ---------- */
.steps{display:grid;gap:1.3rem;counter-reset:step}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start;padding-bottom:1.3rem;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:0;padding-bottom:0}
.step__n{counter-increment:step;font-family:"Cormorant",serif;font-size:1.5rem;font-weight:700;color:var(--rose-ink);width:46px;height:46px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex:none;background:var(--paper)}
.step__n::before{content:counter(step,decimal-leading-zero)}
.step h3{font-size:1.25rem;margin-bottom:.25rem}
.step p{color:var(--muted);font-size:.95rem;margin:0}

/* ---------- Pricing table-ish cards ---------- */
.tiers{display:grid;gap:1.3rem}
.tier{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;display:flex;flex-direction:column}
.tier--feature{background:var(--ink-deep);color:var(--on-deep);border-color:var(--ink-deep)}
.tier--feature h3,.tier--feature .tier__price{color:var(--on-deep)}
.tier__kicker{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-ink);font-weight:500;margin-bottom:.6rem}
.tier--feature .tier__kicker{color:var(--gold-deep)}
.tier h3{font-size:1.6rem;margin-bottom:.4rem}
.tier__price{font-family:"Cormorant",serif;font-size:1.5rem;font-weight:600;color:var(--rose-ink);margin-bottom:1.1rem}
.tier--feature .tier__price{color:var(--rose-deep)}
.tier ul{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem;flex:1}
.tier li{display:flex;gap:.55rem;align-items:flex-start;font-size:.94rem}
.tier .ico{width:1.05em;height:1.05em;color:var(--brass-ink);flex:none;margin-top:.3em}
.tier--feature li{color:var(--on-deep)}
.tier--feature .ico{color:var(--gold-deep)}
.tier .btn{width:100%}

/* ---------- Quote / philosophy block ---------- */
.quote{max-width:760px;margin-inline:auto;text-align:center}
.quote p{font-family:"Cormorant",serif;font-size:clamp(1.6rem,3.6vw,2.5rem);font-weight:500;line-height:1.28;font-style:italic;color:var(--ink)}
.section--deep .quote p{color:var(--on-deep)}
.quote .mark{font-size:3.4rem;color:var(--rose);line-height:0;display:block;margin-bottom:.3rem;font-family:"Cormorant",serif}
.quote cite{display:block;margin-top:1.4rem;font-family:"Jost",sans-serif;font-style:normal;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.section--deep .quote cite{color:var(--on-deep-mut)}

/* ---------- Fact / value list ---------- */
.facts{display:grid;gap:1.2rem}
.fact{display:flex;gap:1rem;align-items:flex-start}
.fact__ico{width:40px;height:40px;flex:none;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:var(--paper)}
.fact__ico .ico{width:19px;height:19px;color:var(--rose-ink)}
.section--deep .fact__ico{background:rgba(244,238,230,.07);border-color:rgba(244,238,230,.18)}
.section--deep .fact__ico .ico{color:var(--rose-deep)}
.fact h3{font-size:1.2rem;margin-bottom:.2rem}
.fact p{color:var(--muted);font-size:.94rem;margin:0}
.section--deep .fact p{color:var(--on-deep-mut)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--ink-deep);color:var(--on-deep);overflow:hidden;text-align:center}
.cta-band__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.22}
.cta-band__in{position:relative;z-index:2;max-width:680px;margin-inline:auto}
.cta-band h2{color:var(--on-deep);margin-bottom:.9rem}
.cta-band p{color:#EFE7DC;margin-bottom:1.8rem}
.cta-band .btns{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.7rem;max-width:820px;margin-inline:auto}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.15rem 1.3rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-weight:500;font-size:1.05rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ico{width:1.1em;height:1.1em;color:var(--rose-ink);flex:none;transition:transform var(--t)}
.faq details[open] summary .ico{transform:rotate(45deg)}
.faq .faq__a{padding:0 1.3rem 1.25rem;color:var(--muted);font-size:.97rem}
.faq .faq__a p{margin:0}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:clamp(1.8rem,5vw,3rem)}
.info-card{display:flex;gap:1rem;align-items:flex-start;padding:1.15rem 0;border-bottom:1px solid var(--line)}
.info-card:last-child{border-bottom:0}
.info-card__ico{width:42px;height:42px;flex:none;border-radius:50%;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.info-card__ico .ico{width:19px;height:19px;color:var(--rose-ink)}
.info-card h3{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-family:"Jost",sans-serif;font-weight:600;color:var(--muted);margin-bottom:.25rem}
.info-card a,.info-card p{font-size:1.05rem;color:var(--ink);margin:0;font-weight:400}
.info-card a:hover{color:var(--rose-ink)}

/* Form */
.form{display:grid;gap:1.1rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,4vw,2.2rem)}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.85rem;font-weight:500;letter-spacing:.02em;color:var(--ink-2)}
.field label .req{color:var(--rose-ink)}
.field input,.field textarea,.field select{
  font:inherit;font-size:1rem;padding:.85rem 1rem;border:1px solid var(--line-2);border-radius:var(--radius);
  background:var(--paper-2);color:var(--ink);transition:border-color var(--t),box-shadow var(--t),background var(--t);width:100%;min-height:48px;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--rose-ink);background:var(--paper);box-shadow:0 0 0 3px rgba(138,79,96,.14)}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#B23B3B;background:#FBF1EF}
.field .err{font-size:.8rem;color:#9F2F2F;min-height:0;display:none}
.field .err.show{display:block}
.field .hint{font-size:.78rem;color:var(--muted)}
.form__row{display:grid;gap:1.1rem}
.form__status{font-size:.92rem;padding:.85rem 1rem;border-radius:var(--radius);display:none}
.form__status.ok{display:block;background:#E9F1E6;color:#2E5424;border:1px solid #BBD3B0}
.form__status.bad{display:block;background:#FBEEEC;color:#8A2C28;border:1px solid #E2BBB6}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;color:var(--muted)}
.consent input{width:18px;height:18px;min-height:18px;margin-top:.2rem;accent-color:var(--rose-ink);flex:none}

/* Map */
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);max-width:100%;background:var(--paper-2)}
.map-wrap iframe{display:block;width:100%;height:320px;border:0;filter:grayscale(.2) sepia(.06)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink-deep);color:var(--on-deep);padding-block:clamp(3rem,7vw,4.5rem) 1.8rem}
.footer-grid{display:grid;gap:2.2rem;margin-bottom:2.5rem}
.footer-brand .brand__name{color:var(--on-deep);font-size:1.5rem}
.footer-brand .brand__sub{color:var(--on-deep-mut)}
.footer-brand p{color:var(--on-deep-mut);font-size:.92rem;margin-top:1rem;max-width:34ch}
.foot-col h4{font-family:"Jost",sans-serif;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:1rem}
.foot-col ul{display:flex;flex-direction:column;gap:.55rem}
.foot-col a,.foot-col p{color:var(--on-deep-mut);font-size:.95rem;margin:0;transition:color var(--t)}
.foot-col a:hover{color:var(--on-deep)}
.foot-col .ln{display:flex;gap:.6rem;align-items:flex-start}
.foot-col .ln .ico{width:1.05em;height:1.05em;color:var(--rose-deep);flex:none;margin-top:.3em}
.footer-bottom{border-top:1px solid rgba(244,238,230,.16);padding-top:1.6rem;display:flex;flex-direction:column;gap:.7rem;font-size:.82rem;color:var(--on-deep-mut)}
.footer-bottom a{color:var(--on-deep-mut);text-decoration:underline;text-underline-offset:2px}
.footer-bottom a:hover{color:var(--on-deep)}
.socials{display:flex;gap:.7rem}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(244,238,230,.22);display:flex;align-items:center;justify-content:center;color:var(--on-deep-mut);transition:all var(--t)}
.socials a:hover{border-color:var(--gold-deep);color:var(--on-deep)}
.socials .ico{width:18px;height:18px}

/* ---------- Page hero (sub pages) ---------- */
.page-head{background:var(--paper-2);border-bottom:1px solid var(--line);padding-block:clamp(2.6rem,7vw,4.4rem) clamp(2rem,5vw,3rem)}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.8rem;color:var(--muted);margin-bottom:1rem}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb li{display:flex;align-items:center;gap:.4rem}
.breadcrumb li:not(:last-child)::after{content:"/";color:var(--line-2)}
.breadcrumb [aria-current="page"]{color:var(--ink-2)}
.page-head h1{font-size:clamp(2.2rem,6vw,3.6rem);margin-bottom:.7rem}
.page-head .lead{max-width:60ch}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-rv="scale"]{transform:scale(.96)}
.reveal[data-rv="scale"].is-visible{transform:none}
.reveal[data-rv="right"]{transform:translateX(26px)}
.reveal[data-rv="right"].is-visible{transform:none}
.stagger>*{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease);transition-delay:calc(var(--i,0)*70ms)}
.stagger.is-visible>*{opacity:1;transform:none}
html.reveal-instant .reveal,html.reveal-instant .stagger>*{opacity:1!important;transform:none!important}

@media (prefers-reduced-motion:reduce){
  .reveal,.stagger>*{opacity:1!important;transform:none!important;transition:none!important}
  .frame img{transition:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:560px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .form__row{grid-template-columns:1fr 1fr}
  .trust__row .sep{display:block}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:768px){
  .facts{grid-template-columns:repeat(2,1fr);gap:1.6rem 2.2rem}
  .tiers{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr}
  .offer{grid-template-columns:1.1fr 1fr}
  .offer--rev .offer__media{order:2}
  .steps{grid-template-columns:repeat(2,1fr);gap:1.3rem 2.4rem}
  .step{border-bottom:0;padding-bottom:0}
}
@media (min-width:880px){
  .nav{display:block}
  .tel-link{display:inline-flex}
  .burger{display:none}
  .split{grid-template-columns:1fr 1fr}
  .split--media-r .split__media{order:2}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr 1.15fr}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .gallery .frame__tag{opacity:1}
}
@media (min-width:1024px){
  .hero__inner{max-width:720px}
  .intro__media .badge{width:140px;height:140px}
}
