/*
Theme Name: Steam & Spice
Theme URI: https://steamandspice.example/
Author: Steam & Spice
Author URI: https://steamandspice.example/
Description: Premium cloud-kitchen WordPress theme for Steam & Spice — steamed momos, fries & more. WhatsApp-first ordering, WooCommerce-aware, Customizer-driven, mobile-first and Core Web Vitals friendly. No jQuery.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: steam-and-spice
Tags: food, restaurant, woocommerce, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, full-width-template
*/

/* =========================================================
   Steam & Spice — Design System
   Colors and fonts are also injected at runtime from the
   Customizer via inc/customizer.php (CSS custom properties).
   The values below are sensible defaults.
   ========================================================= */

:root{
  --sns-red:#E11D2E;
  --sns-red-dark:#B01122;
  --sns-charcoal:#111111;
  --sns-beige:#E8DCC8;
  --sns-beige-soft:#F3ECE0;
  --sns-white:#FFFFFF;
  --sns-surface:#F8F8F8;
  --sns-ink:#1A1A1A;
  --sns-muted:#6B6B6B;
  --sns-line:#ECECEC;

  --sns-font-head:"Oswald", "Arial Narrow", system-ui, sans-serif;
  --sns-font-body:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --sns-maxw:1200px;
  --sns-gap:clamp(16px, 4vw, 32px);
  --sns-radius:18px;
  --sns-radius-sm:12px;
  --sns-shadow:0 10px 30px rgba(17,17,17,.08);
  --sns-shadow-lg:0 24px 60px rgba(17,17,17,.14);
  --sns-shadow-red:0 14px 34px rgba(225,29,46,.28);

  --sns-header-h:80px;
}

/* ---------- Reset / base ---------- */
*,*::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:var(--sns-font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--sns-ink);
  background:var(--sns-white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--sns-red);text-decoration:none;transition:color .2s ease, opacity .2s ease}
a:hover{color:var(--sns-red-dark)}
h1,h2,h3,h4,h5{font-family:var(--sns-font-head);color:var(--sns-charcoal);line-height:1.08;letter-spacing:.4px;margin:0 0 .5em;font-weight:600;text-transform:uppercase}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em;padding-left:1.25em}
button{font-family:inherit}
hr{border:0;border-top:1px solid var(--sns-line);margin:2rem 0}
:focus-visible{outline:3px solid var(--sns-red);outline-offset:2px;border-radius:4px}

.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;margin:-1px;padding:0;overflow:hidden;position:absolute!important;word-wrap:normal!important;
}
.skip-link{position:absolute;left:-999px;top:0;z-index:2000;background:var(--sns-charcoal);color:#fff;padding:12px 18px;border-radius:0 0 8px 0}
.skip-link:focus{left:0;color:#fff}

/* ---------- Layout helpers ---------- */
.sns-container{width:100%;max-width:var(--sns-maxw);margin:0 auto;padding-left:clamp(18px,5vw,40px);padding-right:clamp(18px,5vw,40px)}
.sns-section{padding:clamp(56px,8vw,104px) 0}
.sns-section--surface{background:var(--sns-surface)}
.sns-section--beige{background:linear-gradient(180deg,var(--sns-beige-soft),var(--sns-white))}
.sns-section--charcoal{background:var(--sns-charcoal);color:#fff}
.sns-section--charcoal h1,.sns-section--charcoal h2,.sns-section--charcoal h3{color:#fff}

.sns-eyebrow{
  font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:3px;
  font-size:13px;font-weight:600;color:var(--sns-red);display:inline-flex;align-items:center;gap:10px;margin:0 0 14px
}
.sns-eyebrow::before{content:"";width:26px;height:2px;background:var(--sns-red);display:inline-block}
.sns-section-head{max-width:680px;margin:0 auto clamp(34px,5vw,56px);text-align:center}
.sns-section-head .sns-eyebrow::before{display:none}
.sns-section-head h2{font-size:clamp(28px,4.6vw,46px);letter-spacing:.5px}
.sns-section-head p{color:var(--sns-muted);font-size:clamp(15px,2vw,18px)}

/* Signature chili divider (echoes the logo's dot-chili rule) */
.sns-chili-rule{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0 0}
.sns-chili-rule span{height:2px;width:48px;background:var(--sns-red);border-radius:2px;opacity:.7}
.sns-chili-rule b{width:7px;height:7px;border-radius:50%;background:var(--sns-red)}
.sns-chili-rule b.dot--dark{background:var(--sns-charcoal)}

/* ---------- Buttons ---------- */
.sns-btn{
  --b:var(--sns-red);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:1px;font-weight:600;font-size:15px;
  padding:14px 26px;border-radius:999px;border:2px solid var(--b);background:var(--b);color:#fff;cursor:pointer;
  transition:transform .18s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  line-height:1;text-align:center;
}
.sns-btn:hover{color:#fff;transform:translateY(-2px);box-shadow:var(--sns-shadow-red)}
.sns-btn:active{transform:translateY(0)}
.sns-btn--ghost{background:transparent;color:var(--sns-charcoal);border-color:var(--sns-charcoal)}
.sns-btn--ghost:hover{background:var(--sns-charcoal);color:#fff;box-shadow:var(--sns-shadow)}
.sns-btn--light{background:#fff;color:var(--sns-charcoal);border-color:#fff}
.sns-btn--light:hover{background:var(--sns-beige);color:var(--sns-charcoal);border-color:var(--sns-beige)}
.sns-btn--wa{--b:#25D366;background:#25D366;border-color:#25D366}
.sns-btn--wa:hover{box-shadow:0 14px 34px rgba(37,211,102,.3)}
.sns-btn--sm{padding:10px 18px;font-size:13px}
.sns-btn--lg{padding:16px 30px;font-size:16px}
.sns-btn svg{width:18px;height:18px;flex:none}

/* ---------- Header ---------- */
.sns-header{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--sns-line);transition:box-shadow .25s ease}
.sns-header.is-stuck{box-shadow:0 6px 24px rgba(17,17,17,.08)}
.sns-header__bar{display:flex;align-items:center;gap:22px;min-height:var(--sns-header-h)}
.sns-brand{display:flex;align-items:center;gap:13px;margin-right:auto;padding-right:8px}
.sns-brand img,.sns-brand .custom-logo{height:46px;width:auto}
.sns-brand__txt{display:flex;flex-direction:column;line-height:1}
.sns-brand__name{font-family:var(--sns-font-head);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:20px;color:var(--sns-charcoal)}
.sns-brand__tag{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--sns-red);font-weight:600}

.sns-nav{display:flex;align-items:center;gap:6px}
.sns-nav ul{list-style:none;display:flex;align-items:center;gap:6px;margin:0;padding:0}
.sns-nav a{display:inline-block;padding:10px 15px;color:var(--sns-charcoal);font-weight:600;font-size:15px;border-radius:8px}
.sns-nav a:hover,.sns-nav .current-menu-item>a{color:var(--sns-red);background:var(--sns-surface)}
.sns-nav .sub-menu{position:absolute;background:#fff;box-shadow:var(--sns-shadow);border-radius:12px;padding:8px;display:none;min-width:200px;flex-direction:column;gap:2px}
.sns-nav li{position:relative}
.sns-nav li:hover>.sub-menu{display:flex}

.sns-header__actions{display:flex;align-items:center;gap:12px}
.sns-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--sns-surface);border:1px solid var(--sns-line);color:var(--sns-charcoal);cursor:pointer}
.sns-icon-btn:hover{background:var(--sns-beige);color:var(--sns-charcoal)}
.sns-icon-btn svg{width:20px;height:20px}

.sns-burger{display:none}

/* Mobile menu drawer */
.sns-drawer{position:fixed;inset:0;z-index:1100;visibility:hidden;pointer-events:none}
.sns-drawer__scrim{position:absolute;inset:0;background:rgba(17,17,17,.5);opacity:0;transition:opacity .3s ease}
.sns-drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:#fff;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:22px;overflow-y:auto}
.sns-drawer.is-open{visibility:visible;pointer-events:auto}
.sns-drawer.is-open .sns-drawer__scrim{opacity:1}
.sns-drawer.is-open .sns-drawer__panel{transform:translateX(0)}
.sns-drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sns-drawer__panel nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.sns-drawer__panel nav a{display:block;padding:14px 12px;border-radius:10px;color:var(--sns-charcoal);font-weight:600;font-size:17px;border-bottom:1px solid var(--sns-line)}
.sns-drawer__panel nav a:hover{background:var(--sns-surface);color:var(--sns-red)}
.sns-drawer .sns-btn{width:100%;margin-top:18px}

/* Search overlay */
.sns-search-overlay{position:fixed;inset:0;z-index:1200;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;background:rgba(17,17,17,.55);backdrop-filter:blur(4px);visibility:hidden;opacity:0;transition:opacity .25s ease,visibility .25s ease}
.sns-search-overlay.is-open{visibility:visible;opacity:1}
.sns-search-overlay form{display:flex;gap:10px;width:min(92vw,640px);background:#fff;padding:14px;border-radius:16px;box-shadow:var(--sns-shadow-lg)}
.sns-search-overlay input[type=search]{flex:1;border:0;font-size:18px;padding:12px 14px;background:var(--sns-surface);border-radius:10px}
.sns-search-overlay input:focus{outline:3px solid var(--sns-red)}

/* ---------- HERO ---------- */
.sns-hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 600px at 85% -10%, rgba(225,29,46,.10), transparent 60%),
  linear-gradient(180deg,var(--sns-beige-soft),var(--sns-white) 70%)}
.sns-hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,5vw,56px);align-items:center;padding:clamp(48px,7vw,96px) 0}
.sns-hero__trust{display:flex;flex-wrap:wrap;gap:10px 20px;list-style:none;margin:0 0 20px;padding:0}
.sns-hero__trust li{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--sns-charcoal)}
.sns-hero__trust .tick{width:20px;height:20px;border-radius:50%;background:var(--sns-red);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex:none}
.sns-hero__trust .tick svg{width:12px;height:12px}
.sns-hero h1{font-size:clamp(38px,6.4vw,76px);letter-spacing:.5px;margin-bottom:.25em}
.sns-hero h1 .hl{color:var(--sns-red)}
.sns-hero__sub{font-size:clamp(16px,2.2vw,21px);color:var(--sns-muted);max-width:46ch;margin-bottom:28px}
.sns-hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.sns-hero__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.sns-hero__chip{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:999px;background:#fff;border:1.5px solid var(--sns-line);color:var(--sns-charcoal);font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.6px;font-size:12.5px;font-weight:600;line-height:1;white-space:nowrap;transition:border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}
.sns-hero__chip:hover{border-color:var(--sns-red);color:var(--sns-red);transform:translateY(-2px);box-shadow:var(--sns-shadow)}
.sns-hero__stats{display:flex;gap:28px;margin-top:32px;flex-wrap:wrap}
.sns-hero__stat b{font-family:var(--sns-font-head);font-size:clamp(20px,2.6vw,26px);color:var(--sns-charcoal);display:block;line-height:1.05}
.sns-hero__stat span{font-size:13px;color:var(--sns-muted);text-transform:uppercase;letter-spacing:1px}
.sns-hero__media{position:relative}
.sns-hero__media .sns-hero__plate{position:relative;width:88%;max-width:440px;margin:0 auto;border-radius:50%;aspect-ratio:1;background:radial-gradient(circle at 50% 42%, #fff 0%, #fff 46%, var(--sns-beige-soft) 100%);box-shadow:0 24px 60px -28px rgba(17,17,17,.28);display:flex;align-items:center;justify-content:center;overflow:hidden}
.sns-hero__media .sns-hero__plate.has-photo{background:radial-gradient(circle at 50% 42%, #fff, var(--sns-beige-soft));box-shadow:var(--sns-shadow-lg)}
.sns-hero__media img{width:100%;height:100%;object-fit:cover}
.sns-hero__media .sns-hero__plate:not(.has-photo) img{width:86%;height:86%;object-fit:contain;filter:drop-shadow(0 18px 30px rgba(17,17,17,.18))}
.sns-hero__food{width:96%;height:96%;display:block}
.sns-hero__badge{position:absolute;background:#fff;border-radius:14px;box-shadow:var(--sns-shadow);padding:12px 16px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px}
.sns-hero__badge--1{top:6%;left:-4%}
.sns-hero__badge--2{bottom:8%;right:-2%}
.sns-hero__badge .dot{width:30px;height:30px;border-radius:50%;background:var(--sns-red);color:#fff;display:flex;align-items:center;justify-content:center}
.sns-hero__badge .dot svg{width:16px;height:16px}

/* ---------- Category strip ---------- */
.sns-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2.4vw,24px)}
.sns-cat{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);padding:28px 18px;text-align:center;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.sns-cat:hover{transform:translateY(-6px);box-shadow:var(--sns-shadow);border-color:transparent}
.sns-cat__ic{width:74px;height:74px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--sns-beige-soft);color:var(--sns-red)}
.sns-cat__ic svg{width:38px;height:38px}
.sns-cat h3{font-size:19px;margin:0;letter-spacing:.5px}
.sns-cat span{font-size:13px;color:var(--sns-muted)}

/* ---------- Why choose us ---------- */
.sns-why{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.4vw,26px)}
.sns-why__card{background:#fff;border-radius:var(--sns-radius);padding:30px 24px;border:1px solid var(--sns-line);transition:transform .2s ease,box-shadow .2s ease}
.sns-why__card:hover{transform:translateY(-6px);box-shadow:var(--sns-shadow)}
.sns-why__ic{width:56px;height:56px;border-radius:14px;background:var(--sns-red);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.sns-why__ic svg{width:28px;height:28px}
.sns-why__card h3{font-size:18px;letter-spacing:.4px}
.sns-why__card p{margin:0;color:var(--sns-muted);font-size:14.5px}

/* ---------- Menu / signature cards ---------- */
.sns-menu-toolbar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:30px}
.sns-filters{display:flex;flex-wrap:wrap;gap:8px}
.sns-filter{font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.8px;font-size:13px;font-weight:600;padding:9px 16px;border-radius:999px;border:1.5px solid var(--sns-line);background:#fff;color:var(--sns-charcoal);cursor:pointer;transition:all .18s ease}
.sns-filter:hover{border-color:var(--sns-red);color:var(--sns-red)}
.sns-filter.is-active{background:var(--sns-red);border-color:var(--sns-red);color:#fff}
.sns-menu-search{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--sns-line);border-radius:999px;padding:8px 14px;min-width:220px}
.sns-menu-search input{border:0;outline:0;font-size:15px;flex:1;background:transparent}
.sns-menu-search svg{width:18px;height:18px;color:var(--sns-muted);flex:none}

.sns-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,28px)}
.sns-card{background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}
.sns-card:hover{transform:translateY(-6px);box-shadow:var(--sns-shadow-lg)}
.sns-card__media{position:relative;aspect-ratio:4/3;background:var(--sns-beige-soft);display:flex;align-items:center;justify-content:center;overflow:hidden}
.sns-card__media img{width:100%;height:100%;object-fit:cover}
.sns-card__media .sns-card__ph{width:64px;height:64px;color:var(--sns-red);opacity:.7}
.sns-card__tag{position:absolute;top:12px;left:12px;background:var(--sns-charcoal);color:#fff;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.8px;font-size:11px;padding:6px 12px;border-radius:999px}
.sns-card__spicy{position:absolute;top:12px;right:12px;background:#fff;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700;color:var(--sns-red);display:flex;align-items:center;gap:4px}
.sns-card__body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.sns-card__body h3{font-size:20px;margin:0 0 6px}
.sns-card__desc{color:var(--sns-muted);font-size:14px;margin:0 0 16px;flex:1}
.sns-card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
.sns-card__price{font-family:var(--sns-font-head);font-size:24px;color:var(--sns-charcoal);font-weight:600}
.sns-card__price small{font-size:13px;color:var(--sns-muted);font-weight:400}
.sns-card.is-hidden{display:none}
.sns-noresult{text-align:center;color:var(--sns-muted);padding:30px 0;display:none}
.sns-noresult.is-visible{display:block}

/* ---------- Reviews carousel ---------- */
.sns-reviews{position:relative}
.sns-rev-track{display:flex;gap:clamp(16px,2.4vw,26px);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 18px;-ms-overflow-style:none;scrollbar-width:none}
.sns-rev-track::-webkit-scrollbar{display:none}
.sns-rev{scroll-snap-align:start;flex:0 0 clamp(280px,90%,380px);background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);padding:28px}
.sns-rev__stars{color:var(--sns-red);letter-spacing:3px;font-size:18px;margin-bottom:12px}
.sns-rev__text{font-size:16px;color:var(--sns-ink);margin:0 0 18px}
.sns-rev__who{display:flex;align-items:center;gap:12px}
.sns-rev__av{width:46px;height:46px;border-radius:50%;background:var(--sns-red);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--sns-font-head);font-size:18px;font-weight:600}
.sns-rev__who b{display:block;font-size:15px;color:var(--sns-charcoal)}
.sns-rev__who span{font-size:13px;color:var(--sns-muted)}
.sns-rev-nav{display:flex;gap:10px;justify-content:center;margin-top:18px}
.sns-rev-nav button{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--sns-line);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--sns-charcoal)}
.sns-rev-nav button:hover{background:var(--sns-red);border-color:var(--sns-red);color:#fff}
.sns-rev-nav svg{width:20px;height:20px}

/* ---------- WhatsApp CTA band ---------- */
.sns-wa-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--sns-red),var(--sns-red-dark));color:#fff;border-radius:var(--sns-radius);padding:clamp(36px,5vw,64px);text-align:center}
.sns-wa-band h2{color:#fff;font-size:clamp(26px,4vw,42px)}
.sns-wa-band p{color:rgba(255,255,255,.9);max-width:56ch;margin:0 auto 26px;font-size:17px}
.sns-wa-band__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.sns-wa-band::before,.sns-wa-band::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.08)}
.sns-wa-band::before{width:280px;height:280px;top:-120px;right:-60px}
.sns-wa-band::after{width:200px;height:200px;bottom:-90px;left:-40px}

/* WhatsApp picker modal */
.sns-wa-modal{position:fixed;inset:0;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(17,17,17,.55);backdrop-filter:blur(4px);visibility:hidden;opacity:0;transition:opacity .25s ease,visibility .25s ease}
.sns-wa-modal.is-open{visibility:visible;opacity:1}
.sns-wa-modal__box{background:#fff;border-radius:20px;padding:28px;width:min(94vw,440px);box-shadow:var(--sns-shadow-lg);transform:translateY(12px);transition:transform .25s ease}
.sns-wa-modal.is-open .sns-wa-modal__box{transform:translateY(0)}
.sns-wa-modal__box h3{font-size:22px;margin:0 0 6px}
.sns-wa-modal__box p{color:var(--sns-muted);font-size:14px;margin:0 0 18px}
.sns-wa-list{display:flex;flex-direction:column;gap:10px}
.sns-wa-list a{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:1.5px solid var(--sns-line);color:var(--sns-charcoal);font-weight:600}
.sns-wa-list a:hover{border-color:#25D366;background:#f1fbf4;color:var(--sns-charcoal)}
.sns-wa-list a .wa{width:38px;height:38px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.sns-wa-list a .wa svg{width:20px;height:20px}
.sns-wa-modal__close{margin-top:16px;width:100%;background:none;border:0;color:var(--sns-muted);cursor:pointer;font-weight:600;padding:8px}

/* ---------- Floating WhatsApp + back-to-top ---------- */
.sns-float-wa{position:fixed;right:18px;bottom:18px;z-index:800;width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(37,211,102,.4);border:0;cursor:pointer;animation:sns-pulse 2.4s infinite}
.sns-float-wa svg{width:30px;height:30px}
@keyframes sns-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media (prefers-reduced-motion: reduce){.sns-float-wa{animation:none}}
.sns-top{position:fixed;right:18px;bottom:84px;z-index:800;width:46px;height:46px;border-radius:50%;background:var(--sns-charcoal);color:#fff;border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s ease}
.sns-top.is-visible{opacity:1;visibility:visible;transform:none}
.sns-top svg{width:22px;height:22px}

/* ---------- FAQ accordion ---------- */
.sns-faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.sns-faq__item{border:1px solid var(--sns-line);border-radius:14px;background:#fff;overflow:hidden}
.sns-faq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 22px;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.5px;font-size:16px;color:var(--sns-charcoal);display:flex;align-items:center;justify-content:space-between;gap:14px}
.sns-faq__q .ic{flex:none;width:26px;height:26px;border-radius:50%;background:var(--sns-beige-soft);color:var(--sns-red);display:flex;align-items:center;justify-content:center;transition:transform .25s ease}
.sns-faq__item.is-open .sns-faq__q .ic{transform:rotate(45deg)}
.sns-faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.sns-faq__a-inner{padding:0 22px 20px;color:var(--sns-muted)}

/* ---------- About / story ---------- */
.sns-story{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.sns-story__media{border-radius:var(--sns-radius);overflow:hidden;background:radial-gradient(circle at 50% 40%,#fff,var(--sns-beige));aspect-ratio:1;display:flex;align-items:center;justify-content:center;box-shadow:var(--sns-shadow)}
.sns-story__media img{width:78%;height:78%;object-fit:contain}
.sns-values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px}
.sns-value b{font-family:var(--sns-font-head);font-size:30px;color:var(--sns-red);display:block}
.sns-value span{font-size:13px;color:var(--sns-muted);text-transform:uppercase;letter-spacing:1px}

/* ---------- Contact ---------- */
.sns-contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,52px)}
.sns-contact__cards{display:flex;flex-direction:column;gap:16px}
.sns-contact__row{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--sns-line);border-radius:14px;padding:20px}
.sns-contact__row .ic{width:48px;height:48px;border-radius:12px;background:var(--sns-beige-soft);color:var(--sns-red);display:flex;align-items:center;justify-content:center;flex:none}
.sns-contact__row .ic svg{width:24px;height:24px}
.sns-contact__row b{display:block;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.5px;color:var(--sns-charcoal);font-size:15px;margin-bottom:4px}
.sns-contact__row a{color:var(--sns-ink)}
.sns-contact__row a:hover{color:var(--sns-red)}
.sns-map{border-radius:var(--sns-radius);overflow:hidden;min-height:320px;border:1px solid var(--sns-line);background:var(--sns-surface)}
.sns-map iframe{width:100%;height:100%;min-height:320px;border:0;display:block}
.sns-map__ph{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:320px;color:var(--sns-muted);gap:10px;text-align:center;padding:24px}
.sns-map__ph svg{width:42px;height:42px;color:var(--sns-red)}

/* ---------- Page / single content ---------- */
.sns-page{padding:clamp(40px,6vw,72px) 0}
.sns-page__header{text-align:center;max-width:760px;margin:0 auto clamp(28px,4vw,44px)}
.sns-page__header h1{font-size:clamp(30px,5vw,52px)}
.sns-page__meta{color:var(--sns-muted);font-size:14px}
.sns-content{max-width:760px;margin:0 auto;font-size:17px}
.sns-content img{border-radius:var(--sns-radius);margin:1.4em 0}
.sns-content h2{margin-top:1.6em;font-size:clamp(24px,3.2vw,32px)}
.sns-content h3{margin-top:1.4em;font-size:22px}
.sns-content blockquote{border-left:4px solid var(--sns-red);margin:1.5em 0;padding:6px 0 6px 22px;color:var(--sns-charcoal);font-size:19px}
.sns-content a{text-decoration:underline}
.sns-featured{border-radius:var(--sns-radius);overflow:hidden;margin-bottom:clamp(24px,4vw,40px);max-width:980px;margin-left:auto;margin-right:auto}
.sns-tags a{display:inline-block;background:var(--sns-surface);border:1px solid var(--sns-line);padding:6px 14px;border-radius:999px;font-size:13px;margin:4px 6px 0 0;color:var(--sns-charcoal)}

/* Archive / blog grid */
.sns-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,28px)}
.sns-post{background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);overflow:hidden;display:flex;flex-direction:column}
.sns-post:hover{box-shadow:var(--sns-shadow)}
.sns-post__media{aspect-ratio:16/10;background:var(--sns-beige-soft);overflow:hidden}
.sns-post__media img{width:100%;height:100%;object-fit:cover}
.sns-post__body{padding:20px;display:flex;flex-direction:column;flex:1}
.sns-post__body h3{font-size:19px;margin:0 0 8px}
.sns-post__body h3 a{color:var(--sns-charcoal)}
.sns-post__body h3 a:hover{color:var(--sns-red)}
.sns-post__excerpt{color:var(--sns-muted);font-size:14.5px;flex:1}
.sns-post__date{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--sns-red);font-weight:600;margin-bottom:8px}

/* Pagination */
.sns-pagination{display:flex;justify-content:center;gap:8px;margin-top:clamp(30px,5vw,50px);flex-wrap:wrap}
.sns-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 12px;border-radius:10px;border:1px solid var(--sns-line);background:#fff;color:var(--sns-charcoal);font-weight:600}
.sns-pagination .page-numbers.current,.sns-pagination .page-numbers:hover{background:var(--sns-red);border-color:var(--sns-red);color:#fff}

/* Sidebar / widgets */
.sns-layout{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,48px)}
.sns-layout.has-sidebar{grid-template-columns:minmax(0,1fr) 320px}
.sns-sidebar .widget{background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);padding:22px;margin-bottom:22px}
.sns-sidebar .widget-title{font-size:18px;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--sns-red);display:inline-block}
.sns-sidebar ul{list-style:none;padding:0;margin:0}
.sns-sidebar li{padding:8px 0;border-bottom:1px solid var(--sns-line)}
.sns-sidebar li:last-child{border-bottom:0}

/* Comments */
.sns-comments{max-width:760px;margin:clamp(34px,5vw,56px) auto 0}
.sns-comments__title{font-size:24px;margin-bottom:22px}
.comment-list{list-style:none;padding:0;margin:0}
.comment-list li{margin-bottom:20px}
.comment-body{background:#fff;border:1px solid var(--sns-line);border-radius:14px;padding:18px}
.comment-author{font-weight:700;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:.4px}
.comment-list .children{list-style:none;margin-top:16px;padding-left:24px}
.comment-respond{background:var(--sns-surface);border-radius:var(--sns-radius);padding:24px;margin-top:24px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;padding:12px 14px;border:1px solid var(--sns-line);border-radius:10px;font-family:inherit;font-size:15px;margin-bottom:14px;background:#fff}

/* Forms (CF7 friendly) */
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 input[type=url],.wpcf7 textarea,.wpcf7 select{width:100%;padding:13px 15px;border:1.5px solid var(--sns-line);border-radius:12px;font-family:inherit;font-size:15px;background:#fff;margin-bottom:14px}
.wpcf7 input:focus,.wpcf7 textarea:focus,.wpcf7 select:focus{outline:none;border-color:var(--sns-red)}
.wpcf7 input[type=submit]{background:var(--sns-red);color:#fff;border:0;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:1px;font-weight:600;padding:14px 28px;border-radius:999px;cursor:pointer;font-size:15px}
.wpcf7 input[type=submit]:hover{background:var(--sns-red-dark)}
.sns-form-wrap{background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);padding:clamp(22px,4vw,34px)}

/* 404 / search-empty */
.sns-mid{min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:60px 0}
.sns-mid__inner{max-width:560px}
.sns-mid h1{font-size:clamp(64px,16vw,150px);color:var(--sns-red);margin-bottom:0}
.sns-mid p{color:var(--sns-muted);font-size:18px;margin-bottom:24px}

/* ---------- Footer ---------- */
.sns-footer{background:var(--sns-charcoal);color:#cfcfcf}
.sns-footer a{color:#cfcfcf}
.sns-footer a:hover{color:#fff}
.sns-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(24px,4vw,48px);padding:clamp(48px,6vw,72px) 0}
.sns-footer__brand img{height:56px;margin-bottom:16px}
.sns-footer__brand p{color:#9c9c9c;max-width:34ch}
.sns-footer h4{color:#fff;font-size:16px;letter-spacing:1px;margin-bottom:16px}
.sns-footer ul{list-style:none;padding:0;margin:0}
.sns-footer li{margin-bottom:10px}
.sns-footer__social{display:flex;gap:10px;margin-top:16px}
.sns-footer__social a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff}
.sns-footer__social a:hover{background:var(--sns-red)}
.sns-footer__social svg{width:20px;height:20px}
.sns-footer__hours li{display:flex;justify-content:space-between;gap:14px;color:#bdbdbd}
.sns-footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;font-size:14px;color:#9c9c9c}

/* ---------- Scroll reveal ---------- */
.sns-reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.sns-reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.sns-reveal{opacity:1;transform:none;transition:none}}

/* ---------- WooCommerce ---------- */
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{background:#fff;border:1px solid var(--sns-line);border-radius:var(--sns-radius);padding:16px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}
.woocommerce ul.products li.product:hover{transform:translateY(-6px);box-shadow:var(--sns-shadow)}
.woocommerce ul.products li.product img{border-radius:var(--sns-radius-sm)}
.woocommerce ul.products li.product .price{color:var(--sns-charcoal);font-family:var(--sns-font-head);font-size:22px;font-weight:600}
.woocommerce span.onsale{background:var(--sns-red);border-radius:999px}
.woocommerce .sns-wa-order,.sns-wa-order{display:inline-flex!important;align-items:center;gap:8px;background:#25D366!important;color:#fff!important;border:0!important;font-family:var(--sns-font-head);text-transform:uppercase;letter-spacing:1px;font-weight:600;padding:12px 22px!important;border-radius:999px!important;cursor:pointer;font-size:14px}
.woocommerce .sns-wa-order:hover,.sns-wa-order:hover{background:#1ebe5a!important;color:#fff!important}
.woocommerce .sns-wa-order svg,.sns-wa-order svg{width:18px;height:18px}
.woocommerce div.product .entry-summary .sns-wa-order{padding:15px 30px!important;font-size:16px}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .sns-cats{grid-template-columns:repeat(2,1fr)}
  .sns-why{grid-template-columns:repeat(2,1fr)}
  .sns-cards{grid-template-columns:repeat(2,1fr)}
  .sns-posts{grid-template-columns:repeat(2,1fr)}
  .sns-footer__top{grid-template-columns:1fr 1fr}
  .sns-layout.has-sidebar{grid-template-columns:1fr}
}
@media (max-width:860px){
  .sns-nav,.sns-header__search-btn-desktop{display:none}
  .sns-burger{display:inline-flex}
  .sns-hero__inner{grid-template-columns:1fr;text-align:center}
  .sns-hero__cta,.sns-hero__stats,.sns-hero__chips,.sns-hero__trust{justify-content:center}
  .sns-hero__sub{margin-left:auto;margin-right:auto}
  .sns-hero__media{max-width:420px;margin:0 auto;order:-1}
  .sns-story{grid-template-columns:1fr}
  .sns-contact{grid-template-columns:1fr}
}
@media (max-width:560px){
  .sns-cats{grid-template-columns:1fr 1fr}
  .sns-why{grid-template-columns:1fr}
  .sns-cards{grid-template-columns:1fr}
  .sns-posts{grid-template-columns:1fr}
  .sns-footer__top{grid-template-columns:1fr}
  .sns-brand__txt{display:none}
  .sns-hero__stats{gap:18px}
  .sns-menu-toolbar{flex-direction:column;align-items:stretch}
  .sns-menu-search{min-width:0}
}
@media (max-width:380px){
  body{font-size:15px}
  .sns-hero__badge{display:none}
}
