/*
Theme Name: AFINA
Theme URI: https://afina.sa
Author: AFINA
Author URI: https://afina.sa
Description: قالب ووردبريس فاخر لمنصّة ضيافة AFINA — عربي أولاً (RTL)، أقسام ديناميكية، باقات كـ Custom Post Type، صفحة إعدادات عامة، ورحلة حجز (كونسيرج) تعمل داخل ووردبريس. متوافق مع Gutenberg و Elementor.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: afina
Tags: rtl-language-support, custom-menu, featured-images, translation-ready, full-width-template
*/

/* ============================================================
   AFINA — Design tokens
   ============================================================ */
:root{
  --afina-bg:#EFE4D2;
  --afina-card:#E6D8C1;
  --afina-ink:#32271B;
  --afina-ink-soft:#7B664E;
  --afina-accent:#B15E39;
  --afina-accent-deep:#8C4526;
  --afina-line:rgba(50,39,27,.14);
  --afina-dark:#241A10;
  --afina-cream:#F7F1E6;
  --afina-serif:'Amiri',serif;
  --afina-display:'Cormorant Garamond',serif;
  --afina-sans:'Tajawal',system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  direction:rtl;
  background:var(--afina-bg);
  color:var(--afina-ink);
  font-family:var(--afina-sans);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;color:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit;color:inherit}
::selection{background:rgba(177,94,57,.22)}
h1,h2,h3,h4{margin:0;font-weight:400}
p{margin:0}

.afina-serif{font-family:var(--afina-serif)}
.afina-display{font-family:var(--afina-display)}
.afina-container{max-width:1180px;margin:0 auto;padding-inline:clamp(22px,6vw,56px)}
.afina-accent{color:var(--afina-accent)}
.afina-kicker{font-family:var(--afina-serif);font-size:13px;letter-spacing:.34em;color:var(--afina-accent)}

/* ============================================================
   Keyframes
   ============================================================ */
@keyframes afinaFade{from{opacity:0}to{opacity:1}}
@keyframes afinaFadeOut{from{opacity:1}to{opacity:0}}
@keyframes afinaFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes afinaScaleIn{from{opacity:0;transform:scale(.985)}to{opacity:1;transform:none}}
@keyframes afinaKen{from{transform:scale(1.04)}to{transform:scale(1.14)}}
@keyframes afinaLineW{from{width:0}to{width:130px}}
@keyframes afinaBob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@keyframes afinaRise{from{transform:translateY(112%);opacity:.35}to{transform:translateY(0);opacity:1}}
.afina-ken{animation:afinaKen 26s ease-in-out infinite alternate}
@media (prefers-reduced-motion: reduce){.afina-ken{animation:none}}

/* Scroll reveal — visible by default; only hidden when JS is active (AF-03) */
.afina-reveal{transition:opacity 1.2s cubic-bezier(.2,.7,.2,1),transform 1.2s cubic-bezier(.2,.7,.2,1)}
.afina-js .afina-reveal{opacity:0;transform:translateY(26px)}
.afina-js .afina-reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.afina-reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   Brand intro (curtain lift)
   ============================================================ */
.afina-intro{position:fixed;inset:0;z-index:100;background:linear-gradient(rgba(239,228,210,.92),rgba(239,228,210,.72));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;pointer-events:none;transition:opacity .7s ease,visibility .7s}
.afina-intro.is-gone{opacity:0;visibility:hidden}
.no-js .afina-intro{display:none}
.afina-intro__mark{font-family:var(--afina-display);font-weight:500;font-size:clamp(40px,9vw,80px);letter-spacing:.52em;color:var(--afina-ink);padding-right:.26em;animation:afinaFade .7s cubic-bezier(.2,.7,.2,1) both}
.afina-intro__line{display:block;height:1px;width:0;background:var(--afina-accent);animation:afinaLineW 1.6s .5s cubic-bezier(.2,.7,.2,1) both}
.afina-intro__tag{font-family:var(--afina-serif);font-size:14px;letter-spacing:.42em;color:var(--afina-ink-soft);animation:afinaFade 2s .8s ease both}

/* ============================================================
   Header — floating wordmark + menu button
   ============================================================ */
.afina-wordmark{position:fixed;top:clamp(22px,3vw,34px);left:0;right:0;z-index:42;display:flex;justify-content:center;pointer-events:none;color:var(--afina-cream);transition:opacity .5s ease,color .5s ease}
.afina-wordmark a{pointer-events:auto;display:flex;flex-direction:column;align-items:center;gap:3px;line-height:1;color:inherit}
.afina-wordmark .m{font-family:var(--afina-display);font-weight:500;font-size:clamp(20px,2.6vw,27px);letter-spacing:.52em;padding-right:.26em}
.afina-wordmark .t{font-family:var(--afina-serif);font-size:10px;letter-spacing:.36em;opacity:.82}
.afina-wordmark.is-dark{color:var(--afina-ink)}

.afina-menu-btn{position:fixed;top:clamp(18px,2.6vw,28px);left:clamp(16px,4vw,44px);z-index:44;display:flex;align-items:center;gap:11px;padding:11px 18px;border-radius:999px;background:rgba(50,39,27,.92);color:#F1E7D6;backdrop-filter:blur(8px);opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .55s ease,transform .55s ease,background .4s}
.afina-menu-btn.is-visible{opacity:1;transform:none;pointer-events:auto}
.afina-menu-btn:hover{background:var(--afina-ink)}
.afina-menu-btn .lines{display:flex;flex-direction:column;gap:4px;width:17px;align-items:flex-end}
.afina-menu-btn .lines span{height:1.5px;background:currentColor;border-radius:2px}
.afina-menu-btn .lines span:first-child{width:17px}
.afina-menu-btn .lines span:last-child{width:11px}
.afina-menu-btn .lbl{font-size:13px;letter-spacing:.06em}

/* ============================================================
   Full-screen overlay menu
   ============================================================ */
.afina-overlay{position:fixed;inset:0;z-index:90;background:var(--afina-menu-bg,var(--afina-bg));display:flex;flex-direction:column;visibility:hidden;opacity:0}
.afina-overlay.is-open{visibility:visible;animation:afinaFade .55s cubic-bezier(.2,.7,.2,1) both}
.afina-overlay.is-closing{visibility:visible;animation:afinaFadeOut .46s ease forwards}
.afina-overlay__top{display:flex;align-items:center;justify-content:space-between;padding:22px clamp(18px,5vw,48px)}
.afina-overlay__logo .m{font-family:var(--afina-display);font-weight:500;font-size:22px;letter-spacing:.46em;color:var(--afina-ink);padding-right:.24em}
.afina-overlay__logo .t{font-family:var(--afina-serif);font-size:10px;letter-spacing:.32em;color:var(--afina-accent)}
.afina-overlay__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--afina-ink);border:1px solid var(--afina-line);font-size:22px;line-height:1;transition:background .3s,transform .4s}
.afina-overlay__close:hover{background:var(--afina-card);transform:rotate(90deg)}
.afina-overlay__nav{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:clamp(12px,2.8vw,26px);padding:0 clamp(24px,6vw,64px)}
.afina-overlay__nav a{display:block}
.afina-overlay__nav .mask{display:block;overflow:hidden;padding:4px 6px 8px}
.afina-overlay__nav .word{display:inline-block;font-family:var(--afina-serif);font-weight:400;font-size:clamp(34px,7vw,72px);line-height:1.16;color:var(--afina-ink);transform:translateY(112%);transition:opacity .35s}
.afina-overlay.is-open .afina-overlay__nav .word{animation:afinaRise .95s cubic-bezier(.2,.8,.15,1) forwards}
.afina-overlay__nav a:hover .word{opacity:.55}
.afina-overlay__foot{padding:26px clamp(18px,5vw,48px);border-top:1px solid var(--afina-line);display:flex;flex-wrap:wrap;gap:16px;justify-content:center;text-align:center;font-size:12px;color:var(--afina-ink-soft)}

/* ============================================================
   Hero
   ============================================================ */
.afina-hero{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden}
.afina-hero__img{position:absolute;inset:0}
.afina-hero__img img{width:100%;height:100%;object-fit:cover}
.afina-hero__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,22,14,.82) 0%,rgba(30,22,14,.34) 46%,rgba(30,22,14,.22) 100%)}
.afina-hero__content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(30px,6vw,96px);padding-bottom:clamp(46px,8vw,110px);gap:clamp(20px,3vw,34px)}
.afina-hero__inner{max-width:900px;display:flex;flex-direction:column;gap:clamp(16px,2.4vw,26px);opacity:0;animation:afinaFadeUp 1s .25s cubic-bezier(.2,.7,.2,1) forwards}
.no-js .afina-hero__inner{opacity:1;animation:none}
.afina-hero .kicker{font-family:var(--afina-serif);font-size:clamp(12px,1.6vw,14px);letter-spacing:.42em;color:rgba(243,236,223,.8)}
.afina-hero h1{font-family:var(--afina-serif);font-size:clamp(38px,7.2vw,92px);line-height:1.08;color:var(--afina-cream);text-wrap:balance;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.afina-hero p{max-width:580px;font-size:clamp(15px,2.1vw,20px);line-height:1.8;color:rgba(246,240,228,.9);font-weight:300}
.afina-hero__hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(246,240,228,.7)}
.afina-hero__hint span:first-child{font-size:11px;letter-spacing:.24em}
.afina-hero__hint i{display:block;width:1px;height:34px;background:linear-gradient(rgba(246,240,228,.7),transparent);animation:afinaBob 2.4s ease-in-out infinite}
@media (prefers-reduced-motion: reduce){.afina-hero__inner{opacity:1;animation:none}}

/* ============================================================
   Section shells
   ============================================================ */
.afina-philosophy{padding:clamp(64px,12vw,150px) clamp(22px,6vw,56px);display:flex;justify-content:center}
.afina-philosophy .box{max-width:760px;text-align:center;display:flex;flex-direction:column;gap:clamp(20px,3vw,32px);align-items:center}
.afina-philosophy h2{font-family:var(--afina-serif);font-size:clamp(28px,5vw,52px);line-height:1.28;color:var(--afina-ink);text-wrap:balance}
.afina-philosophy p{max-width:600px;font-size:clamp(15px,2vw,18px);line-height:1.85;color:var(--afina-ink-soft);font-weight:300}
.afina-rule{width:60px;height:1px;background:var(--afina-line);margin-top:8px}

/* Worlds — interactive crossfade explorer */
.afina-worlds{position:relative;height:100vh;min-height:600px;overflow:hidden;background:var(--afina-dark)}
.afina-worlds__panel{position:absolute;inset:0;overflow:hidden;opacity:0;transition:opacity 1.1s cubic-bezier(.4,0,.2,1);pointer-events:none}
.afina-worlds__panel.is-active{opacity:1;pointer-events:auto}
.afina-worlds__panel .img{position:absolute;inset:0}
.afina-worlds__panel .img img{width:100%;height:100%;object-fit:cover}
.afina-worlds__panel .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(24,17,9,.88) 0%,rgba(24,17,9,.3) 50%,rgba(24,17,9,.44) 100%)}
.afina-worlds__panel .idx{position:absolute;top:clamp(88px,13vh,150px);right:clamp(24px,6vw,90px);font-family:var(--afina-display);font-size:clamp(90px,20vw,240px);line-height:.8;color:rgba(247,241,230,.13)}
.afina-worlds__panel .body{position:absolute;bottom:clamp(120px,20vh,190px);right:clamp(24px,6vw,90px);left:clamp(24px,6vw,90px);display:flex;flex-direction:column;gap:clamp(12px,2vw,20px);max-width:640px}
.afina-worlds__panel .body .k{font-family:var(--afina-serif);font-size:13px;letter-spacing:.34em;color:rgba(247,241,230,.72)}
.afina-worlds__panel .body h3{font-family:var(--afina-serif);font-size:clamp(46px,9vw,108px);line-height:1;color:var(--afina-cream)}
.afina-worlds__panel .body p{font-size:clamp(15px,2vw,19px);line-height:1.8;color:rgba(247,241,230,.86);font-weight:300;max-width:520px}
.afina-worlds__cta{align-self:flex-start;margin-top:8px;display:inline-flex;align-items:center;gap:10px;font-size:15px;color:var(--afina-cream);border:1px solid rgba(247,241,230,.5);padding:13px 26px;border-radius:999px;transition:background .3s,color .3s}
.afina-worlds__cta:hover{background:var(--afina-cream);color:var(--afina-dark)}
.afina-worlds__cta .ar{transform:rotate(180deg);display:inline-block}
.afina-worlds__label{position:absolute;top:clamp(26px,4vh,44px);right:clamp(24px,6vw,90px);font-family:var(--afina-serif);font-size:13px;letter-spacing:.36em;color:rgba(247,241,230,.85);z-index:2}
.afina-worlds__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--afina-cream);background:rgba(247,241,230,.08);border:1px solid rgba(247,241,230,.4);backdrop-filter:blur(6px);transition:background .3s,opacity .3s;font-size:20px}
.afina-worlds__arrow:hover{background:rgba(247,241,230,.16)}
.afina-worlds__arrow.prev{right:clamp(16px,3vw,40px)}
.afina-worlds__arrow.next{left:clamp(16px,3vw,40px)}
.afina-worlds__arrow[disabled]{opacity:0;pointer-events:none}
.afina-worlds__arrow .ar{transform:rotate(180deg);display:inline-block}
.afina-worlds__tabs{position:absolute;bottom:clamp(34px,6vh,60px);right:clamp(24px,6vw,90px);left:clamp(24px,6vw,90px);display:flex;flex-wrap:wrap;gap:clamp(18px,3vw,44px);align-items:center;z-index:3}
.afina-worlds__tab{display:flex;flex-direction:column;gap:8px;opacity:.45;transition:opacity .5s}
.afina-worlds__tab.is-active{opacity:1}
.afina-worlds__tab .n{font-family:var(--afina-serif);font-size:clamp(15px,1.8vw,19px);color:var(--afina-cream);white-space:nowrap}
.afina-worlds__tab .u{display:block;height:1.5px;background:var(--afina-accent);transform:scaleX(0);transform-origin:right;transition:transform .5s}
.afina-worlds__tab.is-active .u{transform:scaleX(1)}

/* Banners */
.afina-banners{padding:clamp(56px,9vw,110px) clamp(22px,6vw,56px)}
.afina-banners__wrap{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(16px,2.4vw,26px)}
.afina-banner{position:relative;border-radius:18px;overflow:hidden;min-height:clamp(240px,32vw,360px);display:flex;align-items:flex-end;box-shadow:0 14px 40px rgba(50,39,27,.1)}
.afina-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.afina-banner .scrim{position:absolute;inset:0}
.afina-banner.right .scrim{background:linear-gradient(90deg,rgba(24,17,9,.8) 0%,rgba(24,17,9,.35) 55%,transparent 100%)}
.afina-banner.left .scrim{background:linear-gradient(270deg,rgba(24,17,9,.8) 0%,rgba(24,17,9,.35) 55%,transparent 100%)}
.afina-banner .body{position:relative;padding:clamp(28px,4vw,52px);display:flex;flex-direction:column;gap:12px;max-width:560px}
.afina-banner.left .body{margin-right:auto;align-items:flex-end;text-align:right}
.afina-banner .body .k{font-family:var(--afina-serif);font-size:12px;letter-spacing:.32em;color:#E4B48E}
.afina-banner .body h3{font-family:var(--afina-serif);font-size:clamp(26px,4vw,42px);line-height:1.15;color:var(--afina-cream)}
.afina-banner .body p{font-size:15px;line-height:1.7;color:rgba(247,241,230,.82);font-weight:300}
.afina-btn-cream{align-self:flex-start;margin-top:6px;font-size:14px;color:var(--afina-dark);background:var(--afina-cream);padding:12px 26px;border-radius:999px;transition:transform .3s}
.afina-btn-cream:hover{transform:translateY(-2px)}

/* Invitation */
.afina-invite{position:relative;overflow:hidden;background:var(--afina-ink);color:var(--afina-bg)}
.afina-invite__box{padding:clamp(72px,13vw,160px) clamp(22px,6vw,56px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(22px,3vw,34px);max-width:720px;margin:0 auto}
.afina-invite .k{font-family:var(--afina-serif);font-size:13px;letter-spacing:.34em;color:#D69A7E}
.afina-invite h2{font-family:var(--afina-serif);font-size:clamp(30px,5.6vw,58px);line-height:1.22;color:var(--afina-cream);text-wrap:balance}
.afina-invite p{max-width:520px;font-size:clamp(15px,2vw,18px);line-height:1.8;color:rgba(243,236,223,.72);font-weight:300}

/* Buttons */
.afina-btn-ink{display:inline-flex;align-items:center;gap:12px;font-size:16px;font-weight:500;color:var(--afina-btn-text,var(--afina-bg));background:var(--afina-btn-bg,var(--afina-ink));padding:16px 34px;border-radius:999px;transition:background .3s,transform .35s}
.afina-btn-ink:hover{background:var(--afina-hover,var(--afina-accent-deep));transform:translateY(-1px)}
.afina-btn-ink .ar{transform:rotate(180deg);display:inline-block}

/* Footer */
.afina-footer{position:relative;z-index:1;padding:clamp(40px,7vw,72px) clamp(22px,6vw,56px);display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;border-top:1px solid var(--afina-line)}
.afina-footer .m{font-family:var(--afina-display);font-weight:500;font-size:22px;letter-spacing:.42em;color:var(--afina-ink)}
.afina-footer small{font-size:12px;color:var(--afina-ink-soft)}
.afina-footer a{color:var(--afina-ink-soft)}
.afina-footer a:hover{color:var(--afina-accent)}

/* ============================================================
   Packages archive + single
   ============================================================ */
.afina-page-head{padding:clamp(56px,10vw,120px) clamp(22px,6vw,56px) clamp(30px,5vw,60px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}
.afina-page-head h1{font-family:var(--afina-serif);font-size:clamp(32px,6vw,64px);line-height:1.15;color:var(--afina-ink);max-width:760px;text-wrap:balance}
.afina-page-head p{max-width:560px;font-size:clamp(15px,2vw,18px);line-height:1.8;color:var(--afina-ink-soft);font-weight:300}
.afina-worlds-list{max-width:1180px;margin:0 auto;padding:0 clamp(22px,6vw,56px) clamp(40px,8vw,100px);display:flex;flex-direction:column;gap:clamp(48px,8vw,110px)}
.afina-world-row{display:flex;flex-wrap:wrap;gap:clamp(24px,4vw,56px);align-items:center}
.afina-world-row:nth-child(even){flex-direction:row-reverse}
.afina-world-row .media{flex:1 1 340px;min-width:min(100%,300px);position:relative;height:clamp(300px,42vw,480px);border-radius:16px;overflow:hidden;box-shadow:0 14px 40px rgba(51,42,32,.12)}
.afina-world-row .media img{width:100%;height:100%;object-fit:cover}
.afina-world-row .text{flex:1 1 300px;min-width:min(100%,280px);display:flex;flex-direction:column;gap:18px}
.afina-world-row .text h2{font-family:var(--afina-serif);font-size:clamp(30px,4.6vw,52px);line-height:1.12;color:var(--afina-ink)}
.afina-world-row .text p{font-size:clamp(15px,1.9vw,18px);line-height:1.9;color:var(--afina-ink-soft);font-weight:300;max-width:520px}
.afina-btn-outline{align-self:flex-start;margin-top:8px;display:inline-flex;align-items:center;gap:10px;font-size:15px;color:var(--afina-ink);border:1px solid var(--afina-ink);padding:13px 26px;border-radius:999px;transition:background .3s,color .3s}
.afina-btn-outline:hover{background:var(--afina-ink);color:var(--afina-bg)}
.afina-btn-outline .ar{transform:rotate(180deg);display:inline-block}
.afina-cta-band{padding:clamp(50px,9vw,120px) clamp(22px,6vw,56px);text-align:center;background:var(--afina-card)}
.afina-cta-band .box{max-width:620px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:22px}
.afina-cta-band h2{font-family:var(--afina-serif);font-size:clamp(26px,4.4vw,44px);line-height:1.24;color:var(--afina-ink)}
.afina-cta-band p{font-size:16px;line-height:1.8;color:var(--afina-ink-soft);font-weight:300}

/* generic content page */
.afina-content{max-width:820px;margin:0 auto;padding:clamp(90px,14vw,150px) clamp(22px,6vw,44px) clamp(60px,9vw,110px);line-height:1.9;color:var(--afina-ink)}
.afina-content h1,.afina-content h2{font-family:var(--afina-serif);margin:1.2em 0 .4em}
.afina-content h1{font-size:clamp(30px,5vw,52px)}
.afina-content a{color:var(--afina-accent);text-decoration:underline}
.afina-content img{border-radius:12px;margin:1.2em 0}

/* ============================================================
   Concierge overlay (booking journey)
   ============================================================ */
.afina-concierge{position:fixed;inset:0;z-index:60;background:var(--afina-bg);display:flex;flex-direction:column;overflow:hidden;visibility:hidden;opacity:0}
.afina-concierge.is-open{visibility:visible;animation:afinaFadeUp .5s cubic-bezier(.2,.7,.2,1) both}
.afina-concierge__top{flex:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px clamp(18px,5vw,48px);border-bottom:1px solid var(--afina-line)}
.afina-concierge__back{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--afina-ink-soft);transition:color .3s}
.afina-concierge__back:hover{color:var(--afina-ink)}
.afina-concierge__dots{display:flex;align-items:center;gap:8px}
.afina-concierge__dots i{width:7px;height:7px;border-radius:50%;background:var(--afina-line);transition:all .4s;display:inline-block}
.afina-concierge__dots i.done{background:var(--afina-accent);opacity:.5}
.afina-concierge__dots i.cur{background:var(--afina-accent);width:20px;border-radius:4px}
.afina-concierge__close{font-size:22px;color:var(--afina-ink-soft);line-height:1;width:34px;height:34px;transition:color .3s}
.afina-concierge__close:hover{color:var(--afina-ink)}
.afina-concierge__body{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.afina-concierge__inner{flex:1;width:100%;max-width:900px;margin:0 auto;padding:clamp(28px,6vw,64px) clamp(22px,6vw,48px)}
.afina-step{animation:afinaFadeUp .5s ease both}
.afina-step__head{text-align:center;display:flex;flex-direction:column;gap:12px;margin-bottom:clamp(28px,4vw,44px)}
.afina-step__head .k{font-family:var(--afina-serif);font-size:12px;letter-spacing:.32em;color:var(--afina-accent)}
.afina-step__head h2{font-family:var(--afina-serif);font-size:clamp(28px,5vw,52px);color:var(--afina-ink)}
.afina-who{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));gap:14px;max-width:760px;margin:0 auto}
.afina-who button{text-align:center;padding:clamp(26px,4vw,40px) 18px;border-radius:14px;background:var(--afina-card);transition:transform .3s,box-shadow .3s,background .3s;display:flex;flex-direction:column;align-items:center;gap:10px}
.afina-who button span{font-family:var(--afina-serif);font-size:clamp(20px,3.2vw,26px);color:var(--afina-ink)}
.afina-who button:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(51,42,32,.12)}
.afina-who button.is-sel{background:#33291F}
.afina-who button.is-sel span{color:var(--afina-cream)}
.afina-field-guests{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:22px}
.afina-guest-num{text-align:center;display:flex;flex-direction:column;gap:4px}
.afina-guest-num b{font-family:var(--afina-serif);font-size:clamp(40px,9vw,66px);line-height:1;color:var(--afina-ink);font-weight:400}
.afina-guest-num small{font-size:13px;color:var(--afina-ink-soft);letter-spacing:.04em}
.afina-range{-webkit-appearance:none;appearance:none;height:2px;background:var(--afina-line);border-radius:2px;outline:none;width:100%}
.afina-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:var(--afina-bg);border:1.5px solid var(--afina-accent);box-shadow:0 2px 10px rgba(51,42,32,.18);cursor:pointer;transition:transform .2s}
.afina-range::-webkit-slider-thumb:hover{transform:scale(1.08)}
.afina-range::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--afina-bg);border:1.5px solid var(--afina-accent);cursor:pointer}
.afina-scale{display:flex;justify-content:space-between;font-size:12px;color:var(--afina-ink-soft)}
.afina-cal{max-width:460px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.afina-cal__month{text-align:center;font-family:var(--afina-serif);font-size:20px;color:var(--afina-ink)}
.afina-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.afina-cal__grid .wd{text-align:center;font-size:11px;color:var(--afina-ink-soft);padding-bottom:6px}
.afina-cal__grid button{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:14px;transition:all .25s;position:relative;color:var(--afina-ink);border:1px solid var(--afina-line)}
.afina-cal__grid button.past{opacity:.35;pointer-events:none;border:none}
.afina-cal__grid button.sel{background:var(--afina-accent);color:#fff;font-weight:500;border-color:var(--afina-accent)}
.afina-cal__grid .empty{visibility:hidden}
.afina-legend{display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:var(--afina-ink-soft)}
.afina-rec-card{display:flex;flex-direction:column;background:var(--afina-card);border-radius:18px;overflow:hidden;box-shadow:0 18px 50px rgba(51,42,32,.14);animation:afinaScaleIn .6s ease both}
.afina-rec-card .top{position:relative;height:clamp(220px,36vw,340px)}
.afina-rec-card .top img{width:100%;height:100%;object-fit:cover}
.afina-rec-card .top .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(35,27,18,.6),transparent 55%)}
.afina-rec-card .top .cap{position:absolute;bottom:22px;right:24px;left:24px}
.afina-rec-card .top .cap .k{font-family:var(--afina-serif);font-size:12px;letter-spacing:.3em;color:rgba(246,240,228,.85)}
.afina-rec-card .top .cap h3{font-family:var(--afina-serif);font-size:clamp(30px,5vw,46px);color:var(--afina-cream);margin-top:4px}
.afina-rec-card .content{padding:clamp(22px,4vw,34px);display:flex;flex-direction:column;gap:20px}
.afina-rec-card .content>p{font-size:clamp(15px,1.9vw,17px);line-height:1.85;color:var(--afina-ink-soft);font-weight:300}
.afina-meta{display:flex;flex-wrap:wrap;gap:10px 22px;padding:16px 0;border-top:1px solid var(--afina-line);border-bottom:1px solid var(--afina-line)}
.afina-meta div{display:flex;flex-direction:column;gap:3px}
.afina-meta small{font-size:11px;color:var(--afina-ink-soft)}
.afina-meta span{font-size:15px;color:var(--afina-ink)}
.afina-price{display:flex;align-items:baseline;gap:10px}
.afina-price small{font-size:13px;color:var(--afina-ink-soft)}
.afina-price b{font-family:var(--afina-serif);font-size:clamp(30px,5vw,42px);color:var(--afina-ink);font-weight:400}
.afina-addons{display:flex;flex-direction:column;gap:14px;padding-top:2px}
.afina-addons>span{font-family:var(--afina-serif);font-size:15px;color:var(--afina-ink)}
.afina-addons__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,140px),1fr));gap:10px}
.afina-addon{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:16px 12px;border-radius:13px;transition:all .3s;border:1px solid var(--afina-line);background:var(--afina-bg);color:var(--afina-ink)}
.afina-addon.is-sel{border-color:var(--afina-accent);background:rgba(177,94,57,.08);box-shadow:0 8px 22px rgba(50,39,27,.1)}
.afina-addon .an{font-family:var(--afina-serif);font-size:16px}
.afina-addon .ap{font-size:11px;color:var(--afina-ink-soft)}
.afina-addon .as{font-size:11px;color:var(--afina-accent)}
.afina-total{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-top:12px;border-top:1px solid var(--afina-line)}
.afina-total .lbl{font-size:13px;color:var(--afina-ink-soft)}
.afina-total .val{font-family:var(--afina-serif);font-size:clamp(24px,4vw,34px);color:var(--afina-ink)}
.afina-rec-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.afina-rec-actions .primary{flex:1 1 200px;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:16px;font-weight:500;color:var(--afina-btn-text,var(--afina-bg));background:var(--afina-btn-bg,var(--afina-ink));padding:16px 28px;border-radius:999px;transition:background .3s}
.afina-rec-actions .primary:hover{background:var(--afina-hover,var(--afina-accent-deep))}
.afina-rec-actions .ghost{display:inline-flex;align-items:center;justify-content:center;font-size:15px;color:var(--afina-ink);padding:16px 24px;border-radius:999px;border:1px solid var(--afina-line);transition:border-color .3s}
.afina-rec-actions .ghost:hover{border-color:var(--afina-ink)}
.afina-form{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.afina-form input{width:100%;padding:16px 18px;border-radius:12px;border:1px solid var(--afina-line);background:var(--afina-bg);font-size:16px;transition:border-color .3s}
.afina-form input:focus{border-color:var(--afina-accent);outline:none}
.afina-form input[type=tel]{direction:ltr;text-align:right}
.afina-note{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;background:var(--afina-card);border-radius:12px;font-size:13px;line-height:1.7;color:var(--afina-ink-soft)}
.afina-confirm{max-width:520px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(22px,3.5vw,34px)}
.afina-confirm__tick{width:70px;height:70px;border-radius:50%;border:1.5px solid var(--afina-accent);display:flex;align-items:center;justify-content:center;color:var(--afina-accent);font-size:30px;animation:afinaScaleIn .6s ease both}
.afina-confirm h2{font-family:var(--afina-serif);font-size:clamp(28px,5vw,46px);color:var(--afina-ink)}
.afina-confirm__summary{width:100%;background:var(--afina-card);border-radius:14px;padding:22px;display:flex;flex-direction:column;gap:14px;text-align:right}
.afina-confirm__summary .k{font-family:var(--afina-serif);font-size:13px;letter-spacing:.2em;color:var(--afina-accent)}
.afina-confirm__summary .row{display:flex;justify-content:space-between;gap:12px}
.afina-confirm__summary .row span:first-child{color:var(--afina-ink-soft);font-size:14px}
.afina-confirm__summary .row span:last-child{color:var(--afina-ink);font-size:15px}
.afina-wa{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;font-size:16px;font-weight:500;color:#fff;background:#1FA855;padding:16px 28px;border-radius:999px;transition:transform .3s}
.afina-wa:hover{transform:translateY(-2px)}
.afina-btn-next{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-size:16px;font-weight:500;padding:15px 40px;border-radius:999px;transition:all .3s;background:var(--afina-btn-bg,var(--afina-ink));color:var(--afina-btn-text,var(--afina-bg))}
.afina-btn-next[disabled]{background:var(--afina-line);color:var(--afina-ink-soft);cursor:not-allowed}
.afina-center{display:flex;justify-content:center}

.afina-hidden{display:none !important}

/* Background lines */
.afina-bglines{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;color:var(--afina-accent);opacity:.05}

/* WP admin bar spacing safety */
.admin-bar .afina-wordmark{top:calc(clamp(22px,3vw,34px) + 32px)}
.admin-bar .afina-menu-btn{top:calc(clamp(18px,2.6vw,28px) + 32px)}
