/* ===== Amal Ahmed Zaki — warm, nurturing palette ===== */
:root{
  --cream:#f7f1ea;
  --cream-2:#f0e6da;
  --panel:#ece0d2;
  --card:#fdfaf6;
  --clay:#c98a6b;
  --clay-deep:#b06f4d;
  --peach:#d8a98e;
  --sage:#9bab92;
  --ink:#463a31;
  --ink-soft:#6f6052;
  --muted:#8a7a6c;
  --line:#e6dccf;
  --line-soft:#efe7db;
  --shadow:0 18px 50px -24px rgba(80,55,35,.35);
  --shadow-sm:0 8px 24px -14px rgba(80,55,35,.30);
  --serif:"Newsreader",Georgia,serif;
  --sans:"Mulish",system-ui,sans-serif;
  --radius:22px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* Arabic typography + RTL */
body.ar{font-family:"Tajawal",var(--sans);line-height:1.85}
body.ar h1,body.ar h2,body.ar h3,body.ar .serif{font-family:"El Messiri",var(--serif)}
body.ar .eyebrow{letter-spacing:.04em}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.6rem,5.2vw,4.3rem)}
h2{font-size:clamp(2rem,3.6vw,3rem)}
h3{font-size:1.45rem;font-weight:600}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--clay-deep);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--clay);display:inline-block}
body.ar .eyebrow{text-transform:none;font-size:.95rem;letter-spacing:0}

section{position:relative}
.section-pad{padding:clamp(70px,9vw,130px) 0}
.panel-bg{background:var(--cream-2)}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;white-space:nowrap;
  font-family:var(--sans);font-weight:700;font-size:.98rem;
  padding:.9em 1.7em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s ease,background .25s ease,box-shadow .25s ease,color .25s ease;
}
.btn-primary{background:var(--clay);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--clay);color:var(--clay-deep);transform:translateY(-2px)}
.btn-lg{padding:1.05em 2.1em;font-size:1.05rem}

/* ===== Nav ===== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(247,241,234,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s ease,box-shadow .3s ease;
}
.nav.scrolled{border-color:var(--line);box-shadow:0 6px 24px -18px rgba(80,55,35,.5)}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.32rem;font-weight:600;color:var(--ink);white-space:nowrap}
.nav-inner{display:flex;align-items:center;gap:24px;height:78px}
.brand .mark{
  width:40px;height:40px;border-radius:50%;flex:0 0 auto;
  background:radial-gradient(circle at 35% 30%,var(--peach),var(--clay));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:1.05rem;font-family:var(--sans);
}
.brand small{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-top:1px}
body.ar .brand small{letter-spacing:.04em;text-transform:none}
.nav-links{display:flex;align-items:center;gap:26px;margin-inline-start:auto}
.nav-links a{font-size:.95rem;font-weight:600;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--clay-deep)}
.nav-actions{display:flex;align-items:center;gap:14px}
.lang-toggle{
  display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1.5px solid var(--line);
  border-radius:999px;padding:5px;font-weight:700;font-size:.82rem;
}
.lang-toggle button{
  border:none;background:transparent;cursor:pointer;color:var(--muted);
  padding:.35em .8em;border-radius:999px;font-weight:700;font-family:var(--sans);transition:.2s;
}
.lang-toggle button.active{background:var(--clay);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ===== Hero ===== */
.hero{padding:clamp(40px,6vw,80px) 0 clamp(60px,8vw,110px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,80px);align-items:center}
.hero-loc{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--ink-soft);font-size:.92rem;margin-bottom:22px}
.hero-loc .dot{width:7px;height:7px;border-radius:50%;background:var(--sage)}
.hero h1{margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--clay-deep)}
.hope-line{font-family:var(--serif);font-style:italic;font-size:1.32rem;line-height:1.45;color:var(--clay-deep);margin:-6px 0 22px;max-width:30ch}
body.ar .hope-line{font-style:normal}
.hero-sub{font-size:1.18rem;color:var(--ink-soft);max-width:33ch;margin-bottom:34px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-media{position:relative}
.hero-media .blob{
  position:absolute;inset:-8% -6% -10% -8%;border-radius:46% 54% 58% 42%/52% 44% 56% 48%;
  background:linear-gradient(150deg,var(--peach),var(--clay));opacity:.32;z-index:0;
  animation:float 9s ease-in-out infinite;
}
.hero-portrait{
  display:block;position:relative;z-index:1;width:100%;height:auto;aspect-ratio:2/3;
  border-radius:48% 52% 48% 52%/40% 40% 60% 60%;overflow:hidden;box-shadow:var(--shadow);
}
.hero-badge{
  position:absolute;z-index:2;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:11px 15px;box-shadow:0 14px 34px -16px rgba(80,55,35,.5);display:flex;align-items:center;gap:11px;
}
.hero-badge.b1{bottom:96px;inset-inline-start:-16px}
.hero-badge.b2{bottom:22px;inset-inline-end:-16px}
.hero-badge .ico{width:38px;height:38px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;font-size:1.15rem}
.hero-badge .t{font-size:.72rem;color:var(--clay-deep);font-weight:700;line-height:1.3;text-transform:uppercase;letter-spacing:.08em}
body.ar .hero-badge .t{text-transform:none;letter-spacing:0}
.hero-badge .n{font-family:var(--serif);font-size:1.1rem;font-weight:600;color:var(--ink)}
@keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(-1.5deg)}}

/* trust strip */
.trust{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--card)}
.trust-inner{display:flex;flex-wrap:wrap;gap:28px 56px;align-items:center;justify-content:center;padding:26px 0}
.trust-item{display:flex;align-items:center;gap:12px}
.trust-item .num{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--clay-deep)}
.trust-item .lbl{font-size:.9rem;color:var(--ink-soft);font-weight:600;max-width:16ch;line-height:1.25}

/* ===== Watch & Follow (Instagram) ===== */
.reels{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.reels .instagram-media{
  margin:0 !important;min-width:300px !important;
  width:calc(25% - 17px) !important;max-width:340px !important;
  border-radius:18px !important;box-shadow:var(--shadow-sm) !important;
}
.reels iframe.instagram-media,.reels iframe{min-height:680px !important}

.follow{
  margin-top:44px;display:flex;flex-wrap:wrap;gap:32px;align-items:center;justify-content:space-between;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px 36px;
}
.follow-lead{display:flex;flex-direction:column;gap:8px;max-width:34ch}
.follow-ig{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--clay-deep)}
.follow-sub{color:var(--ink-soft);font-size:1rem;margin-bottom:6px}
.socials-row{display:flex;flex-wrap:wrap;gap:12px}
.soc{display:inline-flex;align-items:center;gap:9px;padding:.7em 1.2em;border-radius:999px;
  border:1.5px solid var(--line);font-weight:700;font-size:.92rem;color:var(--ink);transition:.25s;background:var(--cream)}
.soc:hover{border-color:var(--clay);color:var(--clay-deep);transform:translateY(-2px)}
.soc-ico{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:7px;
  background:var(--cream-2);font-size:.95rem;font-weight:700}
.qr-cards{display:flex;gap:18px;flex-wrap:wrap}
.qr-card{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;
  background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:16px 16px 18px;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.qr-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--clay)}
.qr-img{width:138px;height:138px;border-radius:12px;background:#fff}
.qr-meta b{display:block;font-weight:700;font-size:.95rem;color:var(--ink)}
.qr-meta span{font-size:.82rem;color:var(--muted)}

/* ===== Section heading ===== */
.sec-head{max-width:60ch;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head p{color:var(--ink-soft);font-size:1.1rem;margin-top:16px}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,6vw,80px);align-items:center}
.about-media{position:relative}
.about-media .ph{display:block;width:100%;height:auto;aspect-ratio:2/3;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about-media .stamp{
  position:absolute;inset-block-end:-22px;inset-inline-end:-18px;background:var(--clay);color:#fff;
  border-radius:50%;width:130px;height:130px;display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-style:italic;font-size:1.02rem;line-height:1.25;padding:14px;box-shadow:var(--shadow);
  transform:rotate(-6deg);
}
.about-body p{color:var(--ink-soft);margin-bottom:18px}
.about-body p.lead{font-family:var(--serif);font-size:1.5rem;line-height:1.4;color:var(--ink);font-weight:500}
.sig{font-family:var(--serif);font-style:italic;font-size:1.7rem;color:var(--clay-deep);margin-top:26px}
.about-slogan{
  margin-top:26px;padding:22px 26px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--clay),var(--clay-deep));color:#fff;
  font-family:var(--serif);font-size:1.32rem;line-height:1.4;font-weight:500;
  box-shadow:var(--shadow-sm);position:relative;border:0;
}
.about-slogan::before{
  content:"\201C";position:absolute;top:-6px;inset-inline-start:14px;
  font-family:var(--serif);font-size:3.4rem;line-height:1;color:rgba(255,255,255,.35);
}
.about-slogan span{display:block;padding-inline-start:18px}
.about-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.tag{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.5em 1.1em;font-size:.86rem;font-weight:600;color:var(--ink-soft)}

/* ===== Services ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.svc-card{
  --t:var(--clay);--t-deep:var(--clay-deep);--t-bg:#fff;--t-soft:rgba(201,138,107,.16);
  background:var(--t-bg);border:1px solid var(--line-soft);border-radius:24px;
  display:flex;flex-direction:column;text-align:center;
  transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden;
  box-shadow:0 14px 40px -28px rgba(80,55,35,.5);
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
/* per-card themes */
.svc-card.t-rose{--t:#b65d70;--t-deep:#9c4a5d;--t-bg:#fbf4f4;--t-soft:rgba(182,93,112,.14)}
.svc-card.t-purple{--t:#6f5ca0;--t-deep:#5b4a8a;--t-bg:#f6f4fb;--t-soft:rgba(111,92,160,.14)}
.svc-card.t-green{--t:#6c8a52;--t-deep:#587343;--t-bg:#f3f6ef;--t-soft:rgba(108,138,82,.16)}

.svc-photo{position:relative;height:266px;overflow:hidden}
.svc-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.svc-card:hover .svc-photo img{transform:scale(1.05)}
/* soft curved base that scoops up into the photo */
.svc-photo::after{
  content:"";position:absolute;left:-6%;right:-6%;bottom:-1px;height:52px;
  background:var(--t-bg);border-radius:50% 50% 0 0 / 100% 100% 0 0;
}
.svc-ico{
  position:relative;z-index:1;margin:-14px auto 14px;color:var(--t);
}
.svc-ico svg{width:52px;height:52px;display:block}
.svc-body{padding:0 30px 30px;display:flex;flex-direction:column;flex:1}
.svc-card h3{font-size:1.7rem;color:var(--t-deep);margin-bottom:14px}
.svc-card>p,.svc-card .svc-intro{color:var(--ink-soft);font-size:1.02rem;margin:0 auto 22px;max-width:30ch}
.svc-rule{display:block;width:74%;height:1px;background:var(--t-soft);margin:0 auto 22px}
.svc-list{list-style:none;display:flex;flex-direction:column;gap:14px;text-align:start;margin:0 auto 26px;width:fit-content;max-width:100%}
.svc-list li{display:flex;gap:12px;align-items:center;font-size:1rem;color:var(--t-deep);font-weight:600}
.li-ico{flex:0 0 auto;color:var(--t);display:inline-grid;place-items:center}
.li-ico svg{width:21px;height:21px;display:block}
.svc-more{
  margin:auto 30px 30px;display:block;cursor:pointer;
  background:var(--t);color:#fff;border:none;border-radius:999px;
  padding:.95em 1.6em;font-family:var(--sans);font-weight:700;font-size:1.02rem;
  transition:background .25s ease,transform .25s ease,box-shadow .25s ease;
  box-shadow:0 12px 26px -14px var(--t);
}
.svc-more:hover{background:var(--t-deep);transform:translateY(-2px)}

/* ===== Article modal ===== */
.article-overlay{
  position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:24px;
  background:rgba(46,30,18,.55);backdrop-filter:blur(4px);
  animation:articleFade .25s ease;
}
.article-overlay[hidden]{display:none}
@keyframes articleFade{from{opacity:0}to{opacity:1}}
.article-modal{
  position:relative;background:var(--card);border-radius:var(--radius);
  max-width:680px;width:100%;max-height:88vh;overflow-y:auto;
  padding:clamp(32px,5vw,56px);box-shadow:var(--shadow);
  animation:articleRise .3s cubic-bezier(.2,.7,.3,1);
}
@keyframes articleRise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.article-close{
  position:absolute;top:16px;inset-inline-end:16px;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);background:var(--cream);color:var(--ink);font-size:1.5rem;line-height:1;
  cursor:pointer;display:grid;place-items:center;transition:.2s;
}
.article-close:hover{background:var(--clay);color:#fff;border-color:var(--clay);transform:rotate(90deg)}
.article-kicker{
  font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);
}
body.ar .article-kicker{text-transform:none;letter-spacing:0;font-size:.95rem}
.article-body h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:14px 0 22px}
.article-body p{color:var(--ink-soft);font-size:1.06rem;line-height:1.75;margin-bottom:18px;text-wrap:pretty}
.article-cta{
  display:inline-flex;align-items:center;gap:.55em;margin-top:10px;
  background:var(--clay);color:#fff;font-weight:700;font-size:1rem;
  padding:.85em 1.7em;border-radius:999px;box-shadow:var(--shadow-sm);transition:transform .25s ease,background .25s ease;
}
.article-cta:hover{background:var(--clay-deep);transform:translateY(-2px)}

.aud{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px;justify-content:center}
.aud-pill{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 24px;max-width:380px}
.aud-pill .ico{font-size:1.5rem}
.aud-pill .t b{display:block;font-family:var(--serif);font-size:1.1rem;font-weight:600}
.aud-pill .t span{font-size:.9rem;color:var(--muted)}

/* ===== Process ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding-top:18px}
.step .ring{
  width:54px;height:54px;border-radius:50%;border:2px solid var(--clay);color:var(--clay-deep);
  display:grid;place-items:center;font-family:var(--serif);font-size:1.4rem;font-weight:600;margin-bottom:20px;background:var(--cream);
}
.step h3{font-size:1.2rem;margin-bottom:10px}
.step p{font-size:.96rem;color:var(--ink-soft)}
.step:not(:last-child)::after{
  content:"";position:absolute;top:45px;inset-inline-start:54px;inset-inline-end:-22px;height:2px;
  background:repeating-linear-gradient(90deg,var(--clay) 0 6px,transparent 6px 12px);opacity:.5;
}
body.ar .step:not(:last-child)::after{background:repeating-linear-gradient(270deg,var(--clay) 0 6px,transparent 6px 12px)}

/* ===== Testimonials ===== */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;display:flex;flex-direction:column}
.quote .mark{font-family:var(--serif);font-size:3.4rem;line-height:.6;color:var(--peach);height:34px}
.quote p{color:var(--ink);font-size:1.05rem;margin-bottom:24px;flex:1}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(140deg,var(--peach),var(--clay));display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--sans)}
.quote .who b{display:block;font-weight:700;font-size:.95rem}
.quote .who span{font-size:.84rem;color:var(--muted)}

/* ===== Booking form ===== */
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,72px);align-items:start}
.book-aside h2{margin-bottom:18px}
.book-aside p{color:var(--ink-soft);margin-bottom:26px}
.book-points{list-style:none;display:flex;flex-direction:column;gap:16px}
.book-points li{display:flex;gap:14px;align-items:flex-start}
.book-points .c{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;font-size:.9rem}
.book-points b{font-weight:700}
.book-points span{display:block;color:var(--ink-soft);font-size:.92rem}
form.book{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-sm)}
.field{margin-bottom:20px}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-weight:700;font-size:.86rem;margin-bottom:8px;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--cream);border:1.5px solid var(--line);border-radius:14px;padding:.85em 1em;transition:border-color .2s,box-shadow .2s;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 4px rgba(201,138,107,.15)}
.form-note{font-size:.85rem;color:var(--muted);margin-top:8px;text-align:center}
.form-ok{display:none;background:var(--sage);color:#fff;border-radius:14px;padding:14px 18px;margin-bottom:20px;font-weight:600;text-align:center}
.form-ok.show{display:block}
.form-err{display:none;background:#b4524a;color:#fff;border-radius:14px;padding:14px 18px;margin-bottom:20px;font-weight:600;text-align:center}
.form-err.show{display:block}

/* ===== FAQ ===== */
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:start;font-family:var(--serif);
  font-size:1.22rem;font-weight:600;color:var(--ink);padding:24px 44px 24px 0;position:relative;display:flex;align-items:center;gap:12px}
body.ar .faq-q{padding:24px 0 24px 44px}
.faq-q .pm{position:absolute;inset-inline-end:0;top:26px;width:24px;height:24px;flex:0 0 auto;transition:transform .3s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--clay);border-radius:2px}
.faq-q .pm::before{inset-inline-start:0;top:11px;width:24px;height:2px}
.faq-q .pm::after{left:11px;top:0;width:2px;height:24px;transition:transform .3s}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{color:var(--ink-soft);padding:0 44px 24px 0}
body.ar .faq-a p{padding:0 0 24px 44px}

/* ===== Contact / footer ===== */
.contact{background:var(--ink);color:#f3ece2}
.contact h2{color:#fff}
.contact .eyebrow{color:var(--peach)}
.contact .eyebrow::before{background:var(--peach)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.contact p{color:#d8cabb;margin-top:16px;font-size:1.1rem}
.contact-methods{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.cm{display:flex;align-items:center;gap:16px;padding:18px 22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;transition:.25s}
.cm:hover{background:rgba(255,255,255,.09);transform:translateY(-2px)}
.cm .ico{width:44px;height:44px;border-radius:12px;background:rgba(216,169,142,.2);display:grid;place-items:center;font-size:1.3rem;flex:0 0 auto}
.cm .t b{display:block;font-weight:700}
.cm .t span{font-size:.9rem;color:#bdae9e}
.footer{background:#3a3028;color:#cdbfb0;padding:32px 0}
.footer-inner{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between;font-size:.9rem}
.footer-mail{color:#e8dccd;font-weight:700;transition:color .2s}
.footer-mail:hover{color:#fff}
.footer .socials{display:flex;gap:12px}
.footer .socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;transition:.25s}
.footer .socials a:hover{background:var(--clay);border-color:var(--clay)}

/* reveal — kept as a neutral, always-visible class. (Opacity/transform
   entrances were removed: this preview/compositor can stall mid-transition
   and leave content stuck hidden. Reliability over a scroll animation.) */
.reveal{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid,.about-grid,.book-grid,.contact-grid{grid-template-columns:1fr}
  .hero-media{width:min(440px,82%);justify-self:center;order:-1}
  .svc-grid,.quotes{grid-template-columns:1fr 1fr}
  .reels .instagram-media{width:calc(50% - 11px) !important;max-width:360px !important}
  .follow{flex-direction:column;align-items:flex-start}
  .steps{grid-template-columns:1fr 1fr;gap:36px 22px}
  .step:not(:last-child)::after{display:none}
  .about-media{width:min(440px,90%);justify-self:center}
}
@media(max-width:1000px){
  .nav-links{
    position:fixed;inset:78px 0 auto 0;flex-direction:column;background:var(--cream);
    padding:24px 28px 30px;gap:18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .35s ease;align-items:stretch;margin:0;
  }
  .nav-links.open{transform:none}
  .nav-actions{margin-inline-start:auto}
  .nav-toggle{display:flex}
}
@media(max-width:680px){
  body{font-size:17px}
  .svc-grid,.quotes,.field.row{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .hero-badge.b1{inset-inline-start:0}
  .hero-badge.b2{inset-inline-end:0}
  .nav .btn-primary{padding:.7em 1.2em;font-size:.9rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none;transition:none}
}
