/* =====================================================================
   Phutawan Resort - Design System
   Luxury Nature Resort · Mobile First
   ===================================================================== */
:root{
  --c-primary:#2E5E3B;
  --c-primary-dark:#234a2e;
  --c-secondary:#5E8C61;
  --c-accent:#D9B86A;
  --c-accent-dark:#c2a256;
  --c-bg:#F7F7F2;
  --c-surface:#ffffff;
  --c-text:#2D2D2D;
  --c-muted:#6b6f6a;
  --c-line:#e7e6df;
  --font-head:'Noto Sans Thai',system-ui,sans-serif;
  --font-body:'Prompt',system-ui,sans-serif;
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 4px 16px rgba(33,49,33,.06);
  --shadow:0 12px 40px rgba(33,49,33,.10);
  --shadow-lg:0 24px 70px rgba(33,49,33,.16);
  --container:1280px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);color:var(--c-text);
  background:var(--c-bg);line-height:1.7;font-size:16px;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.font-head{font-family:var(--font-head);font-weight:700;line-height:1.25;color:var(--c-primary-dark)}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
img{max-width:100%;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}
.section{padding:84px 0}
.section--tight{padding:56px 0}
.bg-cream{background:var(--c-bg)}
.bg-soft{background:#fff}
.text-accent{color:var(--c-accent-dark)}
.text-muted{color:var(--c-muted)}

/* ---------- Section heading ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);
  font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.74rem;
  color:var(--c-accent-dark);margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--c-accent)}
.section-title{font-size:clamp(1.7rem,3.4vw,2.6rem);margin:0 0 14px}
.section-sub{max-width:620px;color:var(--c-muted);margin:0 auto}
.text-center .section-sub{margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--c-primary);
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;
  padding:14px 30px;border-radius:999px;border:1.5px solid var(--b);
  background:var(--b);color:#fff;cursor:pointer;transition:.3s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(46,94,59,.28);color:#fff}
.btn-accent{--b:var(--c-accent-dark)}
.btn-accent:hover{box-shadow:0 12px 26px rgba(217,184,106,.4)}
.btn-outline{background:transparent;color:var(--c-primary)}
.btn-outline:hover{background:var(--c-primary);color:#fff}
.btn-light{background:#fff;color:var(--c-primary);border-color:#fff}
.btn-ghost-light{background:transparent;border-color:rgba(255,255,255,.7);color:#fff}
.btn-ghost-light:hover{background:#fff;color:var(--c-primary)}
.btn-sm{padding:10px 20px;font-size:.88rem}
.btn-block{width:100%}

/* ===================================================================
   HEADER / NAV
   =================================================================== */
.topbar{background:var(--c-primary-dark);color:#eef3ee;font-size:.84rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:40px;gap:18px}
.topbar a{color:#eef3ee;opacity:.9}
.topbar a:hover{color:var(--c-accent)}
.topbar .tb-info{display:flex;gap:20px;align-items:center}
.topbar .tb-social{display:flex;gap:14px;align-items:center}
@media(max-width:768px){.topbar .tb-info span:first-child{display:none}}

.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--c-line);transition:.3s var(--ease)}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700;color:var(--c-primary-dark)}
.brand img{height:46px;width:auto}
.brand .brand-name{font-size:1.16rem;line-height:1.1}
.brand .brand-sub{font-size:.66rem;letter-spacing:.22em;color:var(--c-accent-dark);text-transform:uppercase}
.nav-menu{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-menu a{font-weight:500;font-size:.97rem;position:relative;padding:6px 0;color:var(--c-text)}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--c-accent);transition:width .3s var(--ease)}
.nav-menu a:hover,.nav-menu a.active{color:var(--c-primary)}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;color:var(--c-primary);cursor:pointer}
@media(max-width:992px){
  .nav-menu,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
}
/* mobile drawer */
.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;z-index:1100;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg);padding:26px;display:flex;flex-direction:column}
.mobile-drawer.open{transform:translateX(0)}
.mobile-drawer .close{align-self:flex-end;background:none;border:0;font-size:1.8rem;color:var(--c-primary)}
.mobile-drawer ul{list-style:none;padding:0;margin:18px 0 0}
.mobile-drawer li a{display:block;padding:15px 6px;border-bottom:1px solid var(--c-line);font-weight:500;font-size:1.05rem}
.drawer-backdrop{position:fixed;inset:0;background:rgba(20,30,20,.5);z-index:1090;opacity:0;visibility:hidden;transition:.3s}
.drawer-backdrop.open{opacity:1;visibility:visible}

/* ===================================================================
   HERO
   =================================================================== */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero .swiper,.hero .swiper-wrapper,.hero .swiper-slide{position:absolute;inset:0;height:100%}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);transition:transform 7s ease}
.swiper-slide-active .hero-slide{transform:scale(1)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(20,38,24,.82) 0%,rgba(20,38,24,.45) 48%,rgba(20,38,24,.15) 100%);z-index:1}
.hero-inner{position:relative;z-index:3;max-width:680px;padding:120px 0}
.hero .eyebrow{color:var(--c-accent)}
.hero h1{color:#fff;font-size:clamp(2.2rem,5.4vw,4rem);margin:0 0 22px;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero p{font-size:clamp(1rem,1.6vw,1.18rem);color:rgba(255,255,255,.92);max-width:540px;margin:0 0 34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;opacity:.8;font-size:.8rem;text-align:center;letter-spacing:.1em}
.hero-scroll i{display:block;font-size:1.4rem;animation:bounce 1.8s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ===================================================================
   BOOKING WIDGET
   =================================================================== */
.booking-wrap{position:relative;z-index:20;margin-top:-58px}
.booking-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:22px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:16px;align-items:end}
.booking-field label{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:600;color:var(--c-primary);margin-bottom:7px}
.booking-field input,.booking-field select{width:100%;border:1.5px solid var(--c-line);border-radius:var(--radius-sm);padding:12px 14px;font-family:var(--font-body);font-size:.95rem;color:var(--c-text);background:#fcfcfa}
.booking-field input:focus,.booking-field select:focus{outline:none;border-color:var(--c-secondary)}
@media(max-width:992px){.booking-card{grid-template-columns:1fr 1fr}.booking-card .booking-submit{grid-column:1/-1}}
@media(max-width:520px){.booking-card{grid-template-columns:1fr}}
.booking-submit .btn{width:100%;height:48px}

/* Call-to-book bar (replaces booking widget) */
.call-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:30px 34px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;border-top:4px solid var(--c-accent)}
.call-card-text h3{font-size:1.4rem;margin:6px 0 6px}
.call-card-text p{margin:0;color:var(--c-muted);font-size:.95rem}
.call-card-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-lg-call{font-size:1.15rem;padding:16px 32px}
@media(max-width:760px){.call-card{flex-direction:column;align-items:flex-start;text-align:left;padding:26px}.call-card-actions{width:100%}.call-card-actions .btn{flex:1;justify-content:center}}

/* ===================================================================
   FEATURE / HIGHLIGHTS
   =================================================================== */
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:992px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feature-grid{grid-template-columns:1fr}}
.feature-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:32px 26px;transition:.35s var(--ease)}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.feature-ico{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.6rem;color:var(--c-primary);background:linear-gradient(135deg,#eaf1ea,#dbe8dc);margin-bottom:18px}
.feature-card h3{font-size:1.12rem;margin:0 0 8px}
.feature-card p{margin:0;color:var(--c-muted);font-size:.92rem}

/* ---------- About split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:34px}}
.split-media{position:relative}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:480px;object-fit:cover}
.split-media .badge-float{position:absolute;bottom:-22px;right:-18px;background:var(--c-accent);color:#3a2f12;border-radius:var(--radius-sm);padding:18px 24px;box-shadow:var(--shadow);font-family:var(--font-head)}
.split-media .badge-float b{font-size:1.7rem;display:block}
.checklist{list-style:none;padding:0;margin:22px 0 30px;display:grid;gap:12px}
.checklist li{display:flex;gap:12px;align-items:flex-start}
.checklist i{color:var(--c-secondary);font-size:1.2rem;margin-top:2px}

/* ===================================================================
   HOUSE CARDS
   =================================================================== */
.house-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:992px){.house-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.house-grid{grid-template-columns:1fr}}
.house-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.4s var(--ease);display:flex;flex-direction:column}
.house-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.house-thumb{position:relative;aspect-ratio:4/3;overflow:hidden}
.house-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.house-card:hover .house-thumb img{transform:scale(1.08)}
.house-price{position:absolute;bottom:12px;left:12px;background:rgba(255,255,255,.95);color:var(--c-primary-dark);font-weight:600;padding:8px 14px;border-radius:999px;font-size:.86rem;box-shadow:var(--shadow-sm)}
.house-price b{color:var(--c-accent-dark);font-size:1.02rem}
.house-tag{position:absolute;top:12px;left:12px;background:var(--c-accent);color:#3a2f12;font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:999px}
.house-body{padding:22px;display:flex;flex-direction:column;flex:1}
.house-body h3{font-size:1.2rem;margin:0 0 6px}
.house-meta{display:flex;gap:16px;color:var(--c-muted);font-size:.86rem;margin:8px 0 14px}
.house-meta span{display:flex;align-items:center;gap:6px}
.house-body p{color:var(--c-muted);font-size:.9rem;margin:0 0 18px;flex:1}
.house-actions{display:flex;gap:10px;margin-top:auto}

/* ===================================================================
   RESORT CONTENT (editable home block)
   =================================================================== */
.resort-content{max-width:1000px;margin:0 auto}
.rc-features{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:46px 0}
@media(max-width:720px){.rc-features{grid-template-columns:1fr}}
.rc-feature{display:flex;gap:16px;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:24px;transition:.3s var(--ease)}
.rc-feature:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.rc-feature i{font-size:1.7rem;color:var(--c-secondary);flex:none;margin-top:2px}
.rc-feature b{display:block;color:var(--c-primary-dark);margin-bottom:4px;font-family:var(--font-head)}
.rc-feature span{color:var(--c-muted);font-size:.92rem}

.rc-places{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:32px;margin-bottom:46px}
.rc-places h3{font-size:1.25rem;margin:0 0 18px}
.rc-places ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:2px 30px}
@media(max-width:640px){.rc-places ul{grid-template-columns:1fr}}
.rc-places li{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px dashed var(--c-line)}
.rc-places li span{color:var(--c-text)}
.rc-places li b{color:var(--c-accent-dark);white-space:nowrap}

.rc-offer{position:relative;text-align:center;color:#fff;border-radius:var(--radius);padding:50px 34px;overflow:hidden;background:linear-gradient(150deg,#244a2e,#2E5E3B)}
.rc-offer::before{content:"";position:absolute;inset:0;background:url('/images/gallery/g15.jpg') center/cover;opacity:.16}
.rc-offer>*{position:relative;z-index:2}
.rc-offer-tag{display:inline-block;background:var(--c-accent);color:#3a2f12;font-weight:600;font-size:.82rem;padding:6px 16px;border-radius:999px;margin-bottom:14px}
.rc-offer h3{color:#fff;font-size:clamp(1.4rem,3vw,2rem);margin:0 0 10px}
.rc-price{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,6vw,3.4rem);color:var(--c-accent);line-height:1}
.rc-price span{font-size:1.1rem;font-weight:400;color:rgba(255,255,255,.85)}
.rc-offer p{max-width:640px;margin:16px auto;color:rgba(255,255,255,.92)}
.rc-note{font-weight:500}
.rc-contact{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}

/* ===================================================================
   FACILITIES strip
   =================================================================== */
.facility-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
@media(max-width:992px){.facility-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.facility-grid{grid-template-columns:repeat(2,1fr)}}
.facility-item{text-align:center;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-sm);padding:24px 12px;transition:.3s var(--ease)}
.facility-item:hover{background:var(--c-primary);color:#fff;transform:translateY(-4px)}
.facility-item:hover i,.facility-item:hover span{color:#fff}
.facility-item i{font-size:1.9rem;color:var(--c-secondary)}
.facility-item span{display:block;margin-top:10px;font-size:.86rem;font-weight:500}

/* ===================================================================
   GALLERY (masonry)
   =================================================================== */
.masonry{columns:4;column-gap:16px}
@media(max-width:992px){.masonry{columns:3}}
@media(max-width:680px){.masonry{columns:2}}
.masonry a{display:block;margin-bottom:16px;border-radius:var(--radius-sm);overflow:hidden;position:relative;break-inside:avoid}
.masonry img{width:100%;transition:transform .6s var(--ease)}
.masonry a:hover img{transform:scale(1.06)}
.masonry a::after{content:"\F52A";font-family:"bootstrap-icons";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:1.6rem;background:rgba(46,94,59,.45);opacity:0;transition:.3s}
.masonry a:hover::after{opacity:1}

/* ===================================================================
   PLACES
   =================================================================== */
.place-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.place-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.place-grid{grid-template-columns:1fr}}
.place-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-sm)}
.place-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.place-card:hover img{transform:scale(1.08)}
.place-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,30,20,.85),transparent 60%)}
.place-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:22px;color:#fff}
.place-info h3{color:#fff;font-size:1.16rem;margin:0 0 4px}
.place-dist{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--c-accent);font-weight:600}

/* ===================================================================
   REVIEWS
   =================================================================== */
.review-section{background:linear-gradient(160deg,#244a2e,#2E5E3B);color:#fff;position:relative;overflow:hidden}
.review-section .section-title,.review-section .eyebrow{color:#fff}
.review-section .eyebrow{color:var(--c-accent)}
.review-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:32px;backdrop-filter:blur(6px);height:100%}
.review-stars{color:var(--c-accent);font-size:1rem;margin-bottom:14px}
.review-card p{font-size:.98rem;color:rgba(255,255,255,.92);font-style:italic;margin:0 0 20px}
.review-author{display:flex;align-items:center;gap:12px}
.review-avatar{width:46px;height:46px;border-radius:50%;background:var(--c-accent);color:#3a2f12;display:grid;place-items:center;font-weight:700;font-family:var(--font-head)}
.review-author b{display:block;font-size:.95rem}
.review-author small{color:rgba(255,255,255,.7)}

/* ===================================================================
   CONTACT / MAP
   =================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-info-card{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--c-line)}
.contact-info-card .ico{width:48px;height:48px;border-radius:14px;background:#eaf1ea;color:var(--c-primary);display:grid;place-items:center;font-size:1.3rem;flex:none}
.contact-info-card b{display:block;color:var(--c-primary-dark)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.86rem;font-weight:600;margin-bottom:7px;color:var(--c-primary)}
.form-control{width:100%;border:1.5px solid var(--c-line);border-radius:var(--radius-sm);padding:13px 15px;font-family:var(--font-body);font-size:.95rem;background:#fff}
.form-control:focus{outline:none;border-color:var(--c-secondary);box-shadow:0 0 0 3px rgba(94,140,97,.15)}
textarea.form-control{min-height:130px;resize:vertical}
.map-frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);height:100%;min-height:340px}
.map-frame iframe{width:100%;height:100%;border:0;min-height:340px}

/* ===================================================================
   PAGE HEADER (sub pages)
   =================================================================== */
.page-hero{position:relative;color:#fff;text-align:center;padding:130px 0 70px;background-size:cover;background-position:center}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,38,24,.55),rgba(20,38,24,.7))}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(1.9rem,4vw,3rem);margin:0 0 10px}
.breadcrumb-nav{display:flex;gap:8px;justify-content:center;font-size:.9rem;color:rgba(255,255,255,.85)}
.breadcrumb-nav a:hover{color:var(--c-accent)}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{background:var(--c-primary-dark);color:#cdd8cd;padding:70px 0 0;position:relative}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:46px}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:1.05rem;margin:0 0 18px}
.footer-links{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.footer-links a{color:#cdd8cd;font-size:.93rem}
.footer-links a:hover{color:var(--c-accent);padding-left:4px}
.footer-brand img{height:50px;margin-bottom:14px}
.footer-contact li{display:flex;gap:11px;margin-bottom:12px;font-size:.93rem}
.footer-contact i{color:var(--c-accent)}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:1.1rem;transition:.3s}
.footer-social a:hover{background:var(--c-accent);color:#23341f}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;text-align:center;font-size:.85rem;color:#9fb09f;display:flex;flex-direction:column;gap:6px;align-items:center}
.footer-credit{font-size:.82rem;color:#8aa08a}
.footer-credit a{color:#cbd5e1;text-decoration:underline}
.footer-credit a:hover{color:var(--c-accent)}

/* ---------- Floating contacts ---------- */
.float-contact{position:fixed;right:18px;bottom:22px;z-index:900;display:flex;flex-direction:column;gap:12px}
.float-contact a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.5rem;box-shadow:var(--shadow);transition:.3s}
.float-contact a:hover{transform:scale(1.1)}
.fc-line{background:#06C755}
.fc-call{background:var(--c-primary)}

/* ---------- Flash ---------- */
.flash{padding:14px 20px;border-radius:var(--radius-sm);margin-bottom:18px;font-size:.93rem}
.flash-success{background:#e6f4ea;color:#1e6b34;border:1px solid #bfe3c8}
.flash-error{background:#fbe9e9;color:#a12727;border:1px solid #f3c9c9}

/* ---------- 404 ---------- */
.error-page{min-height:70vh;display:grid;place-items:center;text-align:center;padding:60px 0}
.error-page .code{font-family:var(--font-head);font-size:clamp(5rem,18vw,11rem);font-weight:800;color:var(--c-primary);line-height:1;opacity:.18}

/* ---------- AOS fallback ---------- */
[data-aos]{will-change:transform,opacity}

/* ---------- Swiper tweaks ---------- */
.swiper-button-next,.swiper-button-prev{color:var(--c-primary)!important}
.swiper-pagination-bullet-active{background:var(--c-accent)!important}
.hero .swiper-pagination{bottom:90px!important;z-index:5;text-align:left;padding-left:max(22px,calc((100vw - var(--container))/2 + 22px))}
.hero .swiper-pagination-bullet{background:#fff;opacity:.5;width:28px;height:4px;border-radius:2px}
.hero .swiper-pagination-bullet-active{opacity:1;background:var(--c-accent)!important}
