.ssr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--bFont,'Outfit',sans-serif);background:#f5f5f7;min-height:100vh;min-height:100dvh;-webkit-text-size-adjust:100%}
:root{--sage:#8B9E7E;--sage-d:#6B7E5E;--blush:#E8C4B8;--terra:#C4816A;--char:#2C2C2C;--cream:#F7F4EF;--navy:#1a1a2e}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e 0%,#2d5016 100%)}
.login-box{background:white;padding:48px;border-radius:16px;width:420px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
.login-box h1{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;margin-bottom:8px;text-align:center}
.login-box p{text-align:center;color:#888;font-size:0.88rem;margin-bottom:32px}
.login-tabs{display:flex;margin-bottom:24px;border-radius:8px;overflow:hidden;border:1px solid #ddd}
.login-tab{flex:1;padding:10px;text-align:center;cursor:pointer;font-size:0.82rem;font-weight:500;text-transform:uppercase;letter-spacing:0.5px;background:#f8f8f8;transition:all 0.2s}
.login-tab.active{background:var(--navy);color:white}

/* FORMS */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:0.78rem;font-weight:500;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px;color:#555}
.form-input{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-family:'Outfit';outline:0;box-sizing:border-box}
.form-input:focus{border-color:var(--sage)}
*:focus-visible{outline:2px solid var(--sage);outline-offset:2px;border-radius:4px}
.form-input:focus-visible{outline:2px solid var(--sage);outline-offset:0}
textarea.form-input{min-height:80px;resize:vertical}
.field-error{color:#d9534f;font-size:0.78rem;margin-top:4px;display:block}
.form-input.input-error{border-color:#d9534f}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.check-row{display:flex;align-items:center;gap:8px;font-size:0.88rem;cursor:pointer;margin-bottom:8px}
.color-input{width:50px;height:36px;border:1px solid #ddd;border-radius:6px;cursor:pointer;padding:2px}

/* BUTTONS */
.btn{padding:14px 32px;border:none;border-radius:8px;font-family:'Outfit';font-size:0.88rem;cursor:pointer;transition:all 0.2s;width:100%;font-weight:500}
.btn-primary{background:var(--navy);color:white}.btn-primary:hover{background:#2a2a4e}
.btn-green{background:#2d5016;color:white}.btn-green:hover{background:#3d6b20}
.btn-sm{padding:6px 14px;font-size:0.78rem;border-radius:6px}
.btn-outline{background:white;color:#333;border:1px solid #ddd;padding:8px 18px;border-radius:8px;font-family:'Outfit';font-size:0.82rem;cursor:pointer}
.btn-outline:hover{background:#f5f5f5}
.btn-danger{background:#dc3545;color:white;border:none;padding:8px 18px;border-radius:8px;font-family:'Outfit';font-size:0.82rem;cursor:pointer}
.text-link{background:none;border:none;color:#d9534f;cursor:pointer;font-size:0.75rem;font-family:'Outfit'}
.login-hint{margin-top:16px;padding:16px;background:#f8f8f8;border-radius:8px;font-size:0.78rem;color:#888;line-height:1.6}

/* ADMIN */
.admin-wrap{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--navy);color:white;position:fixed;top:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;overflow-y:auto}
.sidebar.green{background:#2d5016}
.sidebar-header{padding:24px 20px 16px}
.sidebar-header h2{font-size:1.1rem;font-weight:600}
.sidebar-header small{font-size:0.7rem;opacity:0.5;margin-top:4px;display:block}
.sidebar-select{margin:0 12px 12px;padding:8px;border-radius:6px;border:1px solid rgba(255,255,255,0.15);background:rgba(255,255,255,0.08);color:white;font-size:0.82rem;font-family:'Outfit';width:calc(100% - 24px)}
.sidebar-select option{color:#333}
.side-link{display:flex;align-items:center;gap:10px;padding:11px 20px;color:rgba(255,255,255,0.65);font-size:0.84rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:'Outfit';transition:all 0.15s}
.side-link:hover,.side-link.active{background:rgba(255,255,255,0.1);color:white}
.main{margin-left:240px;padding:32px;min-height:100vh}
.card{background:white;border-radius:12px;padding:24px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,0.06)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:white;border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,0.06)}
.stat-label{font-size:0.72rem;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:6px}
.stat-val{font-size:1.8rem;font-weight:600}
table{width:100%;border-collapse:collapse;font-size:0.86rem}
th{text-align:left;padding:12px 16px;border-bottom:2px solid #eee;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.5px;color:#888;font-weight:600}
td{padding:12px 16px;border-bottom:1px solid #f0f0f0;vertical-align:top}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:0.7rem;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.badge-pending{background:#fff3cd;color:#856404}
.badge-processing{background:#d1ecf1;color:#0c5460}
.badge-completed{background:#d4edda;color:#155724}
.badge-cancelled{background:#f8d7da;color:#721c24}
.badge-delivered{background:#d4edda;color:#155724}
.badge-refunded{background:#e2d5f1;color:#5a2d82}
.page-title{font-size:1.4rem;margin-bottom:24px;font-weight:600}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex{display:flex;gap:10px;align-items:center}
.saved-msg{position:fixed;top:16px;right:16px;background:#5cb85c;color:white;padding:10px 24px;border-radius:8px;z-index:999;font-size:0.88rem;box-shadow:0 4px 12px rgba(0,0,0,0.15);animation:fadeIn 0.3s}
.saved-msg.saved-err{background:#d9534f}
@keyframes fadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* STOREFRONT */
.sf{min-height:100vh;min-height:100dvh}
.sf-announce{text-align:center;padding:7px 20px;font-size:0.75rem;letter-spacing:1.5px;text-transform:uppercase;color:white}
.sf-nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px 60px;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(0,0,0,0.06)}
.sf-nav>:last-child{justify-self:end}
.sf-nav a{font-size:0.85rem;letter-spacing:0.8px;text-transform:uppercase;cursor:pointer;font-weight:400;text-decoration:none;color:inherit}
.sf-logo{font-size:1.8rem;font-weight:300;letter-spacing:2px;cursor:pointer;text-align:center}
.sf-cart-btn{position:relative;border:none;padding:12px 24px;font-size:0.78rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;color:white}
.sf-cart-cnt{position:absolute;top:-6px;right:-6px;font-size:0.6rem;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white}
.sf-hero{display:grid;grid-template-columns:1fr 1fr;min-height:78vh}
.sf-hero-content{display:flex;flex-direction:column;justify-content:center;padding:60px 80px}
.sf-hero h1{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:3.8rem;font-weight:300;line-height:1.1;margin-bottom:24px}
.sf-hero p{font-size:1.05rem;line-height:1.7;opacity:0.65;max-width:440px;margin-bottom:36px;font-weight:300}
.sf-section{padding:36px 60px}
.sf-section-hdr{text-align:center;margin-bottom:32px}
.sf-overline{font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;display:block;margin-bottom:10px}
.sf-h2{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:2.8rem;font-weight:300}
.sf-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sf-cat{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/4;display:block;color:inherit;text-decoration:none}
.sf-cat-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;opacity:1;transition:transform 0.6s}
.sf-cat:hover .sf-cat-bg{transform:scale(1.05)}
.sf-cat-ov{position:absolute;bottom:0;left:0;right:0;padding:28px 20px;background:linear-gradient(transparent,rgba(0,0,0,0.6));color:white}
.sf-cat-ov h3{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:1.5rem;font-weight:400}
.sf-prods{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.sf-prod{cursor:pointer;transition:transform 0.3s;display:block;color:inherit;text-decoration:none}
.sf-prod:hover{transform:translateY(-3px)}
.sf-prod-img{position:relative;aspect-ratio:1;overflow:hidden;margin-bottom:14px;display:flex;align-items:center;justify-content:center;font-size:3rem;border-radius:4px}
.sf-prod-img:not(:has(img)){opacity:0.35}
.sf-prod-img img{width:100%;height:100%;object-fit:cover}
.sf-prod-tag{position:absolute;top:12px;left:12px;color:white;font-size:0.72rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;z-index:2}
.sf-prod-name{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:1.2rem;font-weight:400;margin-bottom:3px}
.sf-prod-desc{font-size:0.76rem;color:#706B66;font-weight:300;margin-bottom:6px}
.sf-prod-price{font-size:0.95rem;font-weight:500}
.sf-trust{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(0,0,0,0.08);border-bottom:1px solid rgba(0,0,0,0.08)}
.sf-trust-item{display:flex;align-items:center;justify-content:center;gap:14px;padding:26px 20px;border-right:1px solid rgba(0,0,0,0.08)}
.sf-trust-item:last-child{border-right:none}
.sf-trust-ico{font-size:1.1rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;color:white;border-radius:50%;flex-shrink:0}
.sf-review{padding:32px;border:1px solid rgba(0,0,0,0.06)}
.sf-review-stars{font-size:0.82rem;letter-spacing:2px;margin-bottom:14px}
.sf-review blockquote{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:1.1rem;font-style:italic;line-height:1.6;margin-bottom:18px}
.sf-newsletter{padding:50px 60px;text-align:center;color:white}
.sf-newsletter h2{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:2.3rem;font-weight:300;margin-bottom:10px}
.sf-footer{color:white;padding:36px 60px 20px}
.sf-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:28px}
.sf-footer a{display:block;color:rgba(255,255,255,0.7);font-size:0.82rem;margin-bottom:9px;cursor:pointer;text-decoration:none}
.sf-footer-label{font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;color:rgba(255,255,255,0.75);font-weight:600}
.cart-drawer{position:fixed;top:0;right:0;width:420px;max-width:100vw;height:100vh;height:100dvh;background:white;z-index:201;transition:transform 0.3s;display:flex;flex-direction:column;color:#333}
.cart-drawer.no-transition{transition:none!important}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:200}
.checkout-wrap{padding:60px;max-width:700px;margin:0 auto}
.checkout-wrap h1{font-family:var(--hFont,'Cormorant Garamond',serif);font-size:2.4rem;font-weight:300;margin-bottom:40px;text-align:center}
.order-line{display:flex;justify-content:space-between;margin-bottom:8px;font-size:0.9rem}
.order-line.total{font-weight:600;font-size:1.1rem;border-top:1px solid rgba(0,0,0,0.1);padding-top:12px;margin-top:12px}

/* STRIPE ELEMENTS */
.StripeElement{padding:12px;transition:border-color 0.3s}
.StripeElement--focus{border-color:var(--sage) !important}
.StripeElement--invalid{border-color:#d9534f !important}
.StripeElement--complete{border-color:#5cb85c !important}

/* SHARE BUTTONS */
.share-buttons button{transition:opacity 0.2s}
.share-buttons button:hover{opacity:0.85}

/* MODAL OVERLAY */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:300;display:flex;align-items:flex-start;justify-content:center;padding:30px;overflow-y:auto;animation:fadeIn 0.2s}
.modal-a4{background:white;width:800px;max-width:95vw;border-radius:12px;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,0.3);max-height:none;animation:slideUp 0.3s}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* TOP BAR */
.sf-topbar{font-size:0.82rem;letter-spacing:0.5px;font-family:var(--bFont,'Outfit',sans-serif)}
.sf-topbar a{transition:color 0.2s}
.sf-topbar a:hover{color:white !important}
.sf-topbar svg{transition:color 0.2s}

/* CHECKOUT METHOD TOGGLE */
.ck-method-btn{transition:all 0.2s}
.ck-method-btn:hover{opacity:0.9}

/* LANDING PAGES */
.landing-hero{position:relative}
.landing-hero h1{text-wrap:balance}
#enquiry-form .form-input{background:white}
#enquiry-form select.form-input{cursor:pointer;appearance:auto}

/* MOBILE HAMBURGER MENU */
.sf-hamburger{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:8px}
.sf-mobile-nav{position:fixed;inset:0;background:rgba(0,0,0,0.95);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px}
.sf-mobile-nav a{color:white;font-size:1.2rem;letter-spacing:2px;text-transform:uppercase;cursor:pointer;text-decoration:none;font-family:var(--bFont,'Outfit',sans-serif)}
.sf-mobile-nav .close-btn{position:absolute;top:20px;right:24px;color:white;font-size:1.8rem;background:none;border:none;cursor:pointer}

/* SEARCH TOGGLE + PANEL */
.sf-search-toggle{background:none;border:none;cursor:pointer;padding:6px;display:inline-flex;align-items:center;opacity:0.7;transition:opacity 0.2s}
.sf-search-toggle:hover{opacity:1}
.sf-search-panel{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:white;border:1px solid rgba(0,0,0,0.1);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.12);z-index:9999;padding:14px;display:none;animation:fadeIn 0.15s}
.sf-search-panel.open{display:block}
.sf-search-panel input{padding:10px 14px;border:1px solid rgba(0,0,0,0.12);border-radius:8px;font-family:var(--bFont,'Outfit',sans-serif);font-size:1rem;width:100%;outline:none;box-sizing:border-box}
.sf-search-panel input:focus{border-color:var(--sage)}

/* CART BOUNCE ANIMATION */
@keyframes cartBounce{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}
.cart-bounce{animation:cartBounce 0.3s ease}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#1a1a2e;color:white;padding:14px 30px;display:flex;align-items:center;justify-content:space-between;z-index:400;font-size:0.82rem;gap:16px}
.cookie-banner button{padding:8px 20px;border:none;border-radius:6px;font-family:var(--bFont,'Outfit',sans-serif);font-size:0.78rem;cursor:pointer}
.cookie-banner .accept-btn{background:#5cb85c;color:white}
.cookie-banner .decline-btn{background:transparent;color:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.2)}

/* ADMIN/DEV MOBILE HAMBURGER */
.panel-hamburger{display:none;position:fixed;top:12px;left:12px;z-index:10002;border:none;border-radius:8px;padding:8px 14px;font-size:1.4rem;cursor:pointer;font-family:'Outfit';line-height:1;box-shadow:0 2px 8px rgba(0,0,0,0.15);color:white}
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:10000;display:none}
.sidebar-overlay.active{display:block;touch-action:none}
/* Partial refund badge */
.badge-partial_refund{background:#f0e0f5;color:#7b2d8e}
.badge-past_due{background:#fff3cd;color:#856404}

/* ORDER FILTER TABS */
.order-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.order-filter-btn{padding:6px 14px;border:1px solid #ddd;background:white;border-radius:20px;font-family:'Outfit';font-size:0.78rem;cursor:pointer;transition:all 0.2s}
.order-filter-btn.active{background:#2d5016;color:white;border-color:#2d5016}
.order-filter-btn:hover{border-color:#2d5016}

/* PRODUCT IMAGE DROP ZONE */
.drop-zone{border:2px dashed #ccc;border-radius:12px;padding:30px;text-align:center;cursor:pointer;transition:all 0.2s;color:#999;font-size:0.88rem}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--sage);background:rgba(139,158,126,0.05);color:var(--sage)}
.drop-zone img{max-width:120px;max-height:120px;border-radius:8px;margin-bottom:10px;object-fit:cover}

/* DRIVER VIEW CARDS */
.driver-card{background:white;border-radius:12px;padding:20px;margin-bottom:12px;box-shadow:0 1px 3px rgba(0,0,0,0.06);border-left:4px solid #2d5016}
.driver-card h4{font-size:0.95rem;margin-bottom:8px}
.driver-card .driver-addr{font-size:0.85rem;color:#666;margin-bottom:8px}
.driver-card .driver-items{font-size:0.82rem;color:#888;margin-bottom:12px}
.driver-card .driver-slot{display:inline-block;padding:3px 10px;border-radius:12px;font-size:0.7rem;font-weight:500;text-transform:uppercase;margin-bottom:8px}

/* ORDER TRACKING PAGE */
.tracking-wrap{max-width:500px;margin:60px auto;padding:0 24px}
.tracking-result{margin-top:24px}
.tracking-status{display:flex;align-items:center;gap:12px;padding:20px;background:white;border-radius:12px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,0.06)}
.tracking-items{background:white;border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,0.06)}

/* PRODUCT SORTING DROPDOWN */
.sort-select{padding:8px 14px;border:1px solid rgba(0,0,0,0.12);border-radius:6px;font-family:'Outfit';font-size:0.8rem;background:white;cursor:pointer;outline:none}
.sort-select:focus{border-color:var(--sage)}

/* RESPONSIVE - 1024px */
@media(max-width:1024px){
.sf-hero{grid-template-columns:1fr;min-height:auto}
.sf-hero>div:last-child{display:none}
.sf-cats,.sf-prods{grid-template-columns:repeat(2,1fr)}
.sf-trust{grid-template-columns:repeat(2,1fr)}
.stats-grid{grid-template-columns:repeat(2,1fr)}
.sf-footer-grid{grid-template-columns:1fr 1fr}
.sf-nav{padding:16px 24px}
.sf-nav>div:first-child{gap:16px !important}
.sf-hero-content{padding:40px}
.sf-section{padding:50px 30px}
.sf-topbar{padding:8px 24px !important}
.modal-a4{width:95vw}
.sf-search-panel{width:280px}
input[type="date"],input[type="time"]{max-width:100%;min-width:0;box-sizing:border-box}
}

/* GLOBAL: prevent horizontal overflow on storefront */
.sf{max-width:100vw}
html{overflow-x:hidden}

/* RESPONSIVE - 768px */
@media(max-width:768px){
.sf-cats,.sf-prods{grid-template-columns:1fr 1fr}
.sf-trust{grid-template-columns:1fr}
.sf-footer-grid{grid-template-columns:1fr 1fr !important;gap:24px !important}
.stats-grid{grid-template-columns:1fr 1fr}
/* Admin/Dev sidebar: hide off-screen, slide in when .sidebar-open */
.sidebar{position:fixed;top:0;bottom:0;left:-280px;width:260px;z-index:10001;transition:left 0.3s ease;box-shadow:none;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;overflow-y:auto;touch-action:pan-y;display:block}
.sidebar.sidebar-open{left:0;box-shadow:4px 0 20px rgba(0,0,0,0.3)}
body.sidebar-open,html.sidebar-open{overflow:hidden}
.main{margin-left:0;padding-top:56px}
.checkout-wrap{padding:24px 16px;padding-bottom:100px}
input[type="date"],input[type="time"]{max-width:100%;min-width:0;width:100%;box-sizing:border-box;-webkit-appearance:none;appearance:none}
.form-group{overflow:hidden}
.form-row{grid-template-columns:1fr}
.sf-topbar{flex-direction:column;gap:3px;text-align:center;padding:9px 16px !important;font-size:0.78rem}
.modal-overlay{padding:10px;padding-top:env(safe-area-inset-top,10px)}
.sf-hamburger{display:block}
.sf-nav-links{display:none !important}
.sf-search-toggle{display:none !important}
.sf-search-panel{display:none !important}
.panel-hamburger{display:block !important}
.cookie-banner{flex-direction:column;text-align:center;padding:16px}
.sf-hero h1{font-size:2.2rem}
.sf-section{padding:30px 16px}
.sf-newsletter{padding:40px 16px}
.sf-footer{padding:30px 16px 20px !important}
.sf-footer-bottom{flex-direction:column;align-items:flex-start !important;gap:6px !important}
.driver-card{width:100%}
/* Tables scroll horizontally on mobile */
.card{overflow-x:auto;-webkit-overflow-scrolling:touch}
/* Form rows collapse to single column */
.form-row{grid-template-columns:1fr}
/* Grids collapse on mobile */
.grid-responsive{grid-template-columns:1fr !important}
/* Admin: main content padding */
.main{padding:16px 12px;padding-top:56px}
/* Admin: stats grid 2-col on tablet, 1-col on small */
.stats-grid{grid-template-columns:1fr 1fr}
/* Admin: tables & action buttons wrap */
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:0.8rem}
.page-title{font-size:1.3rem !important}
/* Admin: button rows wrap */
[style*="display:flex"][style*="gap"]{flex-wrap:wrap !important}
.modal-a4{width:100vw;max-width:100vw;padding:16px;border-radius:0}
/* Product detail stacks on mobile */
.sf-prod-detail{grid-template-columns:1fr !important;gap:24px !important;padding:16px !important}
/* Reviews don't overflow */
.sf-review{overflow:hidden;word-wrap:break-word}
.sf-review blockquote{word-wrap:break-word;overflow-wrap:break-word}
/* Cart drawer full width on mobile */
.cart-drawer{width:100vw !important;max-width:100vw !important}
/* Checkout button always visible — extra bottom padding */
#pay-btn{position:relative;z-index:10}
/* Prevent any element from exceeding viewport */
img,video,iframe,table{max-width:100% !important}
/* Share buttons wrap */
.share-buttons{flex-wrap:wrap}
}

/* RESPONSIVE - 480px */
@media(max-width:480px){
.sf-prods{grid-template-columns:1fr 1fr;gap:14px}
.sf-cats{grid-template-columns:1fr 1fr;gap:14px}
.sf-hero-content{padding:24px 16px !important}
.checkout-wrap{padding:16px 12px;padding-bottom:100px}
.sf-footer-grid{grid-template-columns:1fr !important}
.sf-footer a{padding:6px 0;margin-bottom:2px}
.sf-footer-bottom a{padding:6px 0}
.sf-hero h1{font-size:1.9rem !important}
/* Admin: stats single column */
.stats-grid{grid-template-columns:1fr !important}
.stat-card{padding:14px}
.main{padding:10px 8px;padding-top:56px}
}

/* ── Flatpickr theme ── */
input.flatpickr-input[readonly]{-webkit-user-select:none;user-select:none}
.flatpickr-calendar{font-family:var(--bFont);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.12);border:1px solid #e8e8e8;width:auto;padding:8px}
.flatpickr-calendar.open{animation:fadeIn 0.15s}
.flatpickr-months{border-radius:8px 8px 0 0;background:var(--datepicker-bg,var(--sage));padding:4px 0}
.flatpickr-months .flatpickr-month{background:transparent;color:white;height:36px}
.flatpickr-current-month{font-size:0.95rem;font-weight:600;padding:0}
.flatpickr-current-month .flatpickr-monthDropdown-months{background:transparent;color:white;font-weight:600;-webkit-appearance:none;appearance:none}
.flatpickr-current-month .flatpickr-monthDropdown-months option{background:white;color:#333}
.flatpickr-current-month input.cur-year{color:white;font-weight:600}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{color:white;fill:white;padding:8px 12px}
.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{color:white;fill:white}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:white}
.flatpickr-weekdays{background:var(--datepicker-bg,var(--sage))}
span.flatpickr-weekday{color:rgba(255,255,255,0.85);font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.flatpickr-day{border-radius:50%;font-size:0.82rem;height:36px;line-height:36px;margin:2px;transition:all 0.15s}
.flatpickr-day:hover{background:rgba(139,158,126,0.12);border-color:transparent}
.flatpickr-day.today{border-color:var(--datepicker-bg,var(--sage));font-weight:600;color:var(--sage-d)}
.flatpickr-day.today:hover{background:rgba(139,158,126,0.12);border-color:var(--datepicker-bg,var(--sage))}
.flatpickr-day.selected,.flatpickr-day.selected:hover,.flatpickr-day.selected:focus{background:var(--datepicker-bg,var(--sage));border-color:var(--datepicker-bg,var(--sage));color:white;font-weight:600}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{color:#ccc;opacity:0.4}
.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:#ccc}
.flatpickr-innerContainer{padding:4px 0}
.flatpickr-input.flatpickr-mobile{font-family:var(--bFont)}
input.flatpickr-input[readonly]+.form-input{cursor:pointer}
