/* ═══════════════════════════════════════
   Soup N' Spud - Main Styles
   Core variables, reset, components, layout
═══════════════════════════════════════ */

:root{
  --cream:#F8F3E8; --cream-dark:#EFE8D5; --warm-white:#FDFAF4;
  --green:#3A5C43; --green-dark:#2D4A35; --green-pale:#EBF2EC;
  --brown:#7A4028; --brown-dark:#5E3020; --brown-pale:#F5EDE8;
  --gold:#C8973A; --gold-pale:#FBF3E3;
  --text:#1E2A22; --text-mid:#4A5E50; --text-light:#7A9080;
  --border:rgba(58,92,67,.12);
  --shadow-sm:0 2px 8px rgba(30,42,34,.06);
  --shadow-md:0 8px 32px rgba(30,42,34,.10);
  --shadow-lg:0 20px 60px rgba(30,42,34,.14);
  --r-card:20px; --r-btn:12px;
  --transition:0.28s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-tap-highlight-color:transparent;}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;}
img{display:block;width:100%;object-fit:cover;}
button{cursor:pointer;font-family:inherit;border:none;}

/* NAV */
nav{position:sticky;top:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:70px;background:rgba(248,243,232,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);}
.nav-back{display:flex;align-items:center;gap:7px;background:none;color:var(--text-mid);font-size:14px;font-weight:500;transition:color var(--transition);visibility:hidden;}
.nav-back.visible{visibility:visible;}
.nav-back:hover{color:var(--green);}
.nav-back svg{transition:transform var(--transition);}
.nav-back:hover svg{transform:translateX(-3px);}
.nav-brand{position:absolute;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:1px;}
.nav-brand-logo{width:44px;height:44px;object-fit:contain;}
.nav-brand-name{font-family:'Lora',serif;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--green);}
.nav-right{display:flex;align-items:center;gap:12px;}
.nav-cart{display:flex;align-items:center;gap:8px;background:var(--green);color:#fff;padding:9px 18px;border-radius:40px;font-size:13px;font-weight:600;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);position:relative;}
.nav-cart:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(58,92,67,.3);}
.cart-count{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:50%;background:var(--gold);color:var(--text);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1);}
.cart-count.bump{transform:scale(1.4);}
/* USER ACCOUNT */
.nav-account{display:flex;align-items:center;gap:6px;background:transparent;border:1.5px solid var(--green);color:var(--green);padding:8px 16px;border-radius:40px;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);}
.nav-account:hover{background:var(--green);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(58,92,67,.2);}
.nav-account.logged-in{background:var(--green);color:#fff;border-color:var(--green);}
.nav-account.logged-in:hover{background:var(--green-dark);}
.nav-account-icon{font-size:15px;}
.user-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--warm-white);border:1px solid rgba(30,42,34,.1);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.12);min-width:220px;z-index:210;padding:6px;display:none;animation:fadeUp .2s ease both;}
.user-menu.open{display:block;}
.user-menu-header{padding:14px 16px 10px;border-bottom:1px solid rgba(30,42,34,.06);}
.user-menu-name{font-family:'Lora',serif;font-size:15px;font-weight:700;color:var(--text);}
.user-menu-email{font-size:12px;color:rgba(30,42,34,.5);margin-top:2px;}
.user-menu-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13px;font-weight:500;color:var(--text);border-radius:10px;cursor:pointer;transition:background .15s;}
.user-menu-item:hover{background:rgba(58,92,67,.06);}
.user-menu-item.danger{color:#c0392b;}
.user-menu-item.danger:hover{background:rgba(192,57,43,.06);}
.user-menu-divider{height:1px;background:rgba(30,42,34,.06);margin:4px 0;}
/* Auth Modal */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;display:none;align-items:center;justify-content:center;backdrop-filter:blur(3px);}
.auth-overlay.open{display:flex;}
.auth-box{background:var(--warm-white);border-radius:20px;width:min(420px,92vw);padding:40px 36px 32px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.15);animation:fadeUp .3s ease both;position:relative;}
.auth-close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text);opacity:.5;transition:opacity .15s;}
.auth-close:hover{opacity:1;}
.auth-logo{font-size:36px;margin-bottom:8px;}
.auth-title{font-family:'Lora',serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px;}
.auth-sub{font-size:13px;color:rgba(30,42,34,.5);margin-bottom:24px;}
.auth-tabs{display:flex;gap:4px;background:rgba(58,92,67,.06);border-radius:10px;padding:3px;margin-bottom:22px;}
.auth-tab{flex:1;padding:9px;font-size:13px;font-weight:600;border-radius:8px;border:none;cursor:pointer;background:transparent;color:rgba(30,42,34,.5);transition:all .2s;}
.auth-tab.active{background:#fff;color:var(--green);box-shadow:0 2px 8px rgba(0,0,0,.06);}
.auth-form{display:none;text-align:left;}
.auth-form.active{display:block;}
.auth-field{margin-bottom:14px;}
.auth-label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:5px;letter-spacing:.03em;}
.auth-input{width:100%;padding:11px 14px;border:1.5px solid rgba(30,42,34,.12);border-radius:10px;font-size:14px;font-family:'DM Sans',sans-serif;background:#fff;transition:border-color .2s;box-sizing:border-box;}
.auth-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(58,92,67,.08);}
.auth-input.error{border-color:#e74c3c;}
.auth-err{font-size:12px;color:#e74c3c;margin-top:4px;display:none;}
.auth-err.show{display:block;}
.btn-auth{width:100%;padding:13px;border:none;border-radius:12px;background:var(--green);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s,transform .2s;margin-top:8px;}
.btn-auth:hover{background:var(--green-dark);transform:translateY(-1px);}
.auth-footer{margin-top:18px;font-size:13px;color:rgba(30,42,34,.5);}
.auth-footer a{color:var(--green);font-weight:600;cursor:pointer;text-decoration:none;}
/* Account Panel (order history) */
.account-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:250;display:none;backdrop-filter:blur(3px);}
.account-overlay.open{display:block;}
.account-panel{position:fixed;top:0;right:-480px;width:min(460px,100vw);height:100vh;background:var(--warm-white);z-index:251;overflow-y:auto;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.1);}
.account-panel.open{right:0;}
.account-panel-head{padding:28px 28px 20px;border-bottom:1px solid rgba(30,42,34,.06);display:flex;justify-content:space-between;align-items:center;}
.account-panel-title{font-family:'Lora',serif;font-size:22px;font-weight:700;color:var(--text);}
.account-panel-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text);opacity:.5;}
.account-panel-close:hover{opacity:1;}
.account-section{padding:20px 28px;}
.account-section-title{font-size:13px;font-weight:700;color:rgba(30,42,34,.4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;}
.account-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(30,42,34,.04);font-size:14px;}
.account-info-label{color:rgba(30,42,34,.5);font-weight:500;}
.account-info-value{color:var(--text);font-weight:600;}
.account-order-card{background:#fff;border:1px solid rgba(30,42,34,.08);border-radius:12px;padding:16px;margin-bottom:12px;}
.account-order-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.account-order-num{font-weight:700;color:var(--green);font-size:14px;}
.account-order-date{font-size:12px;color:rgba(30,42,34,.4);}
.account-order-items{font-size:13px;color:var(--text);margin-bottom:6px;}
.account-order-total{font-size:14px;font-weight:700;color:var(--text);}
.account-no-orders{text-align:center;padding:40px 20px;color:rgba(30,42,34,.35);font-size:14px;}
.account-no-orders span{display:block;font-size:36px;margin-bottom:10px;}
/* EMAIL NOTIFICATIONS */
.email-settings-grid{display:grid;grid-template-columns:1fr;gap:14px;}
.email-setting-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid rgba(30,42,34,.08);border-radius:14px;padding:18px 20px;}
.email-setting-head{display:flex;align-items:center;gap:14px;}
.email-setting-icon{font-size:24px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(58,92,67,.06);border-radius:12px;}
.email-setting-title{font-weight:700;font-size:14px;color:var(--text);}
.email-setting-desc{font-size:12px;color:rgba(30,42,34,.45);margin-top:2px;}
.email-toggle{position:relative;width:48px;height:26px;flex-shrink:0;}
.email-toggle input{opacity:0;width:0;height:0;}
.email-toggle-slider{position:absolute;inset:0;background:rgba(30,42,34,.15);border-radius:26px;cursor:pointer;transition:background .25s;}
.email-toggle-slider::before{content:'';position:absolute;left:3px;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .25s;box-shadow:0 1px 4px rgba(0,0,0,.12);}
.email-toggle input:checked+.email-toggle-slider{background:var(--green);}
.email-toggle input:checked+.email-toggle-slider::before{transform:translateX(22px);}
.email-admin-field{max-width:400px;}
.email-log-empty{text-align:center;padding:40px 20px;color:rgba(30,42,34,.35);font-size:13px;background:rgba(58,92,67,.02);border-radius:12px;border:1px dashed rgba(30,42,34,.1);}
.email-preview{background:#fff;border:1px solid rgba(30,42,34,.1);border-radius:14px;margin-bottom:12px;overflow:hidden;}
.email-preview-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:rgba(58,92,67,.04);border-bottom:1px solid rgba(30,42,34,.06);cursor:pointer;}
.email-preview-bar:hover{background:rgba(58,92,67,.07);}
.email-preview-meta{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--text);}
.email-preview-type{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:6px;color:#fff;}
.email-preview-type.confirm{background:var(--green);}
.email-preview-type.admin{background:var(--gold);}
.email-preview-type.status{background:#6366f1;}
.email-preview-time{font-size:11px;color:rgba(30,42,34,.4);font-weight:400;}
.email-preview-body{display:none;padding:20px;font-size:13px;line-height:1.7;color:var(--text);}
.email-preview-body.open{display:block;}
.email-preview-subject{font-weight:700;margin-bottom:8px;font-size:14px;}
.email-preview-to{color:rgba(30,42,34,.5);margin-bottom:12px;font-size:12px;}
.email-preview-content{background:rgba(58,92,67,.02);border-radius:10px;padding:16px;border:1px solid rgba(30,42,34,.05);}
.email-preview-content .ep-header{text-align:center;padding-bottom:14px;border-bottom:1px solid rgba(30,42,34,.06);margin-bottom:14px;}
.email-preview-content .ep-logo{font-size:28px;}
.email-preview-content .ep-biz{font-family:'Lora',serif;font-weight:700;font-size:16px;margin-top:4px;}
.email-preview-content .ep-body{font-size:13px;line-height:1.7;}
.email-preview-content .ep-footer{margin-top:14px;padding-top:12px;border-top:1px solid rgba(30,42,34,.06);text-align:center;font-size:11px;color:rgba(30,42,34,.35);}
/* STOCK / AVAILABILITY */
.stock-toggle{position:relative;width:40px;height:22px;flex-shrink:0;display:inline-block;vertical-align:middle;}
.stock-toggle input{opacity:0;width:0;height:0;}
.stock-toggle-slider{position:absolute;inset:0;background:rgba(30,42,34,.15);border-radius:22px;cursor:pointer;transition:background .25s;}
.stock-toggle-slider::before{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.1);}
.stock-toggle input:checked+.stock-toggle-slider{background:var(--green);}
.stock-toggle input:checked+.stock-toggle-slider::before{transform:translateX(18px);}
.stock-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;white-space:nowrap;}
.stock-badge.in-stock{background:rgba(58,92,67,.08);color:var(--green);}
.stock-badge.low-stock{background:rgba(234,179,8,.12);color:#b45309;}
.stock-badge.out-of-stock{background:rgba(220,38,38,.08);color:#dc2626;}
.stock-input{width:60px;padding:5px 8px;border:1.5px solid rgba(30,42,34,.12);border-radius:8px;font-size:12px;font-family:'DM Sans',sans-serif;text-align:center;}
.stock-input:focus{outline:none;border-color:var(--green);}
.card-sold-out{position:absolute;inset:0;background:rgba(248,243,232,.7);z-index:5;display:flex;align-items:center;justify-content:center;border-radius:20px;}
.card-sold-out-badge{background:#dc2626;color:#fff;font-size:13px;font-weight:700;padding:10px 24px;border-radius:40px;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 4px 16px rgba(220,38,38,.2);}
.card.unavailable .card-img-wrap img,.card.unavailable .card-img-wrap>div{filter:grayscale(.7);opacity:.6;}
.card.unavailable .btn-card{opacity:.4;pointer-events:none;}
.admin-avail-cell{display:flex;align-items:center;gap:8px;}
/* DELIVERY ZONES & CALENDAR */
.dz-zone-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.dz-zone-card{background:#fff;border:1px solid rgba(30,42,34,.08);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.dz-zone-name{font-weight:700;font-size:14px;color:var(--text);min-width:100px;}
.dz-zone-zips{font-size:12px;color:var(--text-mid);flex:1;min-width:160px;}
.dz-zone-fee{font-weight:700;font-size:14px;color:var(--green);white-space:nowrap;}
.dz-zone-actions{display:flex;gap:6px;}
.dz-zone-actions button{padding:5px 10px;font-size:11px;font-weight:600;border-radius:8px;border:none;cursor:pointer;}
.dz-btn-edit{background:rgba(58,92,67,.08);color:var(--green);}
.dz-btn-del{background:rgba(220,38,38,.06);color:#dc2626;}
.dz-add-form{background:rgba(58,92,67,.03);border:1px dashed rgba(58,92,67,.2);border-radius:14px;padding:18px;margin-bottom:16px;}
.dz-form-row{display:grid;grid-template-columns:1fr 2fr 100px;gap:10px;align-items:end;}
.dz-form-row .settings-input{margin-top:0;}
.dz-blackout-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.dz-blackout-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(220,38,38,.06);color:#dc2626;font-size:11px;font-weight:600;padding:5px 10px;border-radius:8px;}
.dz-blackout-chip button{background:none;border:none;color:#dc2626;cursor:pointer;font-size:14px;line-height:1;padding:0;}
/* Checkout zip feedback */
.co-zip-feedback{font-size:11px;margin-top:4px;font-weight:600;}
.co-zip-feedback.ok{color:var(--green);}
.co-zip-feedback.err{color:#dc2626;}
.co-zip-feedback.warn{color:#b45309;}
/* Calendar picker */
.cal-wrap{background:#fff;border:1.5px solid rgba(30,42,34,.1);border-radius:14px;overflow:hidden;user-select:none;}
.cal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:rgba(58,92,67,.04);border-bottom:1px solid rgba(30,42,34,.06);}
.cal-header button{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text);padding:4px 8px;border-radius:8px;transition:background .15s;}
.cal-header button:hover{background:rgba(58,92,67,.1);}
.cal-month{font-family:'Lora',serif;font-size:15px;font-weight:700;color:var(--text);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;}
.cal-dow{font-size:10px;font-weight:700;color:var(--text-light);padding:10px 0 6px;letter-spacing:.08em;text-transform:uppercase;}
.cal-day{padding:8px 4px;font-size:13px;cursor:pointer;border-radius:10px;transition:all .15s;position:relative;}
.cal-day:hover:not(.disabled):not(.selected){background:rgba(58,92,67,.06);}
.cal-day.today{font-weight:700;color:var(--green);}
.cal-day.today::after{content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--green);}
.cal-day.selected{background:var(--green);color:#fff;font-weight:700;}
.cal-day.selected::after{background:#fff;}
.cal-day.disabled{color:rgba(30,42,34,.2);cursor:default;pointer-events:none;}
.cal-day.blackout{color:rgba(220,38,38,.35);text-decoration:line-through;}
.cal-day.empty{pointer-events:none;}
.co-delivery-fee{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;margin-top:10px;background:rgba(58,92,67,.04);border-radius:10px;font-size:13px;}
.co-delivery-fee-label{color:var(--text-mid);}
.co-delivery-fee-val{font-weight:700;color:var(--green);}
/* SUBSCRIPTIONS */
.sub-section{margin-top:48px;}
.sub-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px;}
.sub-plan{background:var(--warm-white);border:2px solid rgba(30,42,34,.08);border-radius:20px;padding:28px 24px;text-align:center;position:relative;transition:all .3s;}
.sub-plan:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.08);}
.sub-plan.popular{border-color:var(--green);box-shadow:0 8px 30px rgba(58,92,67,.12);}
.sub-plan.popular::before{content:'Most Popular';position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:4px 16px;border-radius:20px;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;}
.sub-plan-icon{font-size:36px;margin-bottom:10px;}
.sub-plan-name{font-family:'Lora',serif;font-size:20px;font-weight:700;color:var(--text);margin-bottom:4px;}
.sub-plan-freq{font-size:12px;color:var(--text-light);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:16px;}
.sub-plan-price{font-family:'Lora',serif;font-size:36px;font-weight:700;color:var(--green);}
.sub-plan-price sup{font-size:18px;vertical-align:super;font-weight:400;}
.sub-plan-price sub{font-size:13px;font-weight:400;color:var(--text-light);}
.sub-plan-save{display:inline-block;background:rgba(200,151,58,.12);color:var(--gold);font-size:11px;font-weight:700;padding:4px 12px;border-radius:8px;margin:10px 0 14px;letter-spacing:.04em;}
.sub-plan-features{list-style:none;text-align:left;font-size:13px;color:var(--text-mid);line-height:2.2;}
.sub-plan-features li::before{content:'✓';color:var(--green);font-weight:700;margin-right:8px;}
.btn-subscribe{width:100%;padding:13px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .25s;margin-top:18px;border:none;}
.btn-subscribe.primary{background:var(--green);color:#fff;}
.btn-subscribe.primary:hover{background:var(--green-dark);transform:translateY(-1px);}
.btn-subscribe.outline{background:transparent;border:2px solid var(--green);color:var(--green);}
.btn-subscribe.outline:hover{background:var(--green);color:#fff;}
/* Subscription badge on account */
.sub-active-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(58,92,67,.08);color:var(--green);font-size:12px;font-weight:700;padding:5px 12px;border-radius:8px;}
.sub-active-card{background:#fff;border:1.5px solid rgba(58,92,67,.15);border-radius:14px;padding:18px;margin-top:10px;}
.sub-active-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.sub-active-card-plan{font-family:'Lora',serif;font-size:17px;font-weight:700;color:var(--text);}
.sub-active-card-status{font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.06em;}
.sub-active-card-status.active{background:rgba(58,92,67,.08);color:var(--green);}
.sub-active-card-status.paused{background:rgba(234,179,8,.1);color:#b45309;}
.sub-active-card-status.cancelled{background:rgba(220,38,38,.06);color:#dc2626;}
.sub-active-card-info{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px;}
.sub-active-card-label{color:var(--text-light);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;}
.sub-active-card-actions{display:flex;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid rgba(30,42,34,.06);}
.sub-active-card-actions button{padding:8px 16px;font-size:12px;font-weight:600;border-radius:10px;cursor:pointer;border:none;transition:all .2s;}
.btn-sub-pause{background:rgba(234,179,8,.1);color:#b45309;}
.btn-sub-pause:hover{background:rgba(234,179,8,.2);}
.btn-sub-cancel{background:rgba(220,38,38,.06);color:#dc2626;}
.btn-sub-cancel:hover{background:rgba(220,38,38,.12);}
.btn-sub-resume{background:rgba(58,92,67,.08);color:var(--green);}
.btn-sub-resume:hover{background:rgba(58,92,67,.15);}
/* Admin sub list */
.admin-sub-card{background:#fff;border:1px solid rgba(30,42,34,.08);border-radius:12px;padding:16px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.admin-sub-info{display:flex;align-items:center;gap:14px;}
.admin-sub-name{font-weight:700;font-size:14px;color:var(--text);}
.admin-sub-detail{font-size:12px;color:var(--text-light);}
.admin-sub-right{display:flex;align-items:center;gap:10px;}
@media(max-width:768px){.sub-plans{grid-template-columns:1fr;}}
@media(max-width:520px){.sub-active-card-info{grid-template-columns:1fr;}.admin-sub-card{flex-direction:column;align-items:flex-start;}}
/* CONTENT PAGES */
.content-page{max-width:860px;margin:0 auto;padding:60px 48px 100px;}
.content-hero{text-align:center;margin-bottom:48px;}
.content-hero-tag{display:inline-flex;align-items:center;gap:6px;background:var(--green-pale);color:var(--green);border:1px solid rgba(58,92,67,.18);border-radius:40px;padding:5px 14px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;}
.content-hero-h1{font-family:'Lora',serif;font-size:clamp(32px,5vw,48px);font-weight:700;color:var(--text);line-height:1.15;margin-bottom:14px;}
.content-hero-h1 em{font-style:italic;color:var(--green);}
.content-hero-sub{font-size:16px;color:var(--text-mid);max-width:560px;margin:0 auto;line-height:1.7;}
.content-section{margin-bottom:48px;}
.content-section h2{font-family:'Lora',serif;font-size:24px;font-weight:700;color:var(--text);margin-bottom:14px;}
.content-section p{font-size:15px;color:var(--text-mid);line-height:1.8;margin-bottom:16px;}
.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:24px;}
.content-card{background:var(--warm-white);border:1px solid rgba(30,42,34,.06);border-radius:18px;padding:28px 24px;transition:transform .25s,box-shadow .25s;}
.content-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.06);}
.content-card-icon{font-size:32px;margin-bottom:12px;}
.content-card h3{font-family:'Lora',serif;font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px;}
.content-card p{font-size:13px;color:var(--text-mid);line-height:1.7;}
.content-img{width:100%;border-radius:18px;overflow:hidden;margin:24px 0;}
.content-img img{width:100%;height:280px;object-fit:cover;}
.content-quote{background:var(--green-pale);border-radius:16px;padding:28px 32px;margin:28px 0;border-left:4px solid var(--green);}
.content-quote p{font-family:'Lora',serif;font-size:17px;font-style:italic;color:var(--text);line-height:1.7;margin:0;}
.content-quote cite{display:block;margin-top:10px;font-size:13px;font-style:normal;font-weight:600;color:var(--green);}
/* NUTRITION TABLE */
.nutrition-table{width:100%;border-collapse:collapse;background:var(--warm-white);border-radius:14px;overflow:hidden;border:1px solid rgba(30,42,34,.06);}
.nutrition-table th{background:var(--green);color:#fff;padding:12px 16px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:left;}
.nutrition-table td{padding:12px 16px;font-size:14px;color:var(--text);border-bottom:1px solid rgba(30,42,34,.04);}
.nutrition-table tr:last-child td{border-bottom:none;}
.nutrition-table tr:hover td{background:rgba(58,92,67,.02);}
/* CONTACT FORM */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:32px;}
.contact-form-wrap{background:var(--warm-white);border:1px solid rgba(30,42,34,.06);border-radius:18px;padding:32px;}
.contact-field{margin-bottom:16px;}
.contact-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light);margin-bottom:6px;}
.contact-input,.contact-textarea{width:100%;padding:12px 14px;border:1.5px solid rgba(30,42,34,.1);border-radius:10px;font-size:14px;font-family:'DM Sans',sans-serif;background:#fff;transition:border-color .2s;box-sizing:border-box;}
.contact-input:focus,.contact-textarea:focus{outline:none;border-color:var(--green);}
.contact-textarea{resize:vertical;min-height:120px;}
.btn-contact{background:var(--green);color:#fff;border:none;border-radius:12px;padding:14px 32px;font-size:15px;font-weight:700;cursor:pointer;width:100%;transition:background .25s,transform .25s;}
.btn-contact:hover{background:var(--green-dark);transform:translateY(-1px);}
.contact-info-card{background:var(--warm-white);border:1px solid rgba(30,42,34,.06);border-radius:18px;padding:28px;}
.contact-info-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px;}
.contact-info-item:last-child{margin-bottom:0;}
.contact-info-icon{font-size:20px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--green-pale);border-radius:12px;flex-shrink:0;}
.contact-info-label{font-size:12px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;}
.contact-info-val{font-size:14px;color:var(--text);line-height:1.6;}
/* CATERING QUOTE FORM */
.quote-form-overlay{position:fixed;inset:0;background:rgba(30,42,34,.55);backdrop-filter:blur(8px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s;}
.quote-form-overlay.open{opacity:1;pointer-events:all;}
.quote-form{background:var(--warm-white);border-radius:24px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);padding:32px;}
.quote-form-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;}
.quote-form-title{font-family:'Lora',serif;font-size:22px;font-weight:700;color:var(--text);}
.quote-form-close{background:none;border:none;font-size:24px;color:var(--text-light);cursor:pointer;}
/* LOADING SPINNER */
.spinner-overlay{position:fixed;inset:0;background:rgba(248,243,232,.85);z-index:9000;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.spinner-overlay.show{opacity:1;pointer-events:all;}
.spinner{width:44px;height:44px;border:3px solid rgba(58,92,67,.15);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.spinner-text{margin-top:14px;font-size:14px;font-weight:600;color:var(--text);}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;}.content-page{padding:40px 20px 80px;}}
@media(max-width:520px){.content-page{padding:28px 16px 60px;}.content-quote{padding:20px;}.quote-form{border-radius:18px;padding:24px;}}
.progress-bar{position:fixed;top:70px;left:0;height:2px;z-index:201;background:linear-gradient(90deg,var(--green),var(--gold));width:0%;transition:width .1s linear;}

/* VIEWS */
.view{display:none;}
.view.active{display:block;animation:viewIn .38s ease both;}
@keyframes viewIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

/* HERO */
.hero{max-width:1160px;margin:0 auto;padding:80px 48px 0;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;min-height:calc(100vh - 70px);}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--green-pale);color:var(--green);border:1px solid rgba(58,92,67,.18);border-radius:40px;padding:5px 14px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:28px;animation:fadeUp .5s ease both;}
.hero-h1{font-family:'Lora',serif;font-size:clamp(42px,5.5vw,72px);font-weight:700;line-height:1.07;color:var(--text);margin-bottom:22px;animation:fadeUp .55s .05s ease both;}
.hero-h1 em{font-style:italic;color:var(--green);}
.hero-sub{font-size:16px;color:var(--text-mid);line-height:1.72;max-width:420px;margin-bottom:44px;animation:fadeUp .55s .1s ease both;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .55s .15s ease both;margin-bottom:52px;}
.btn-hero-primary{background:var(--green);color:#fff;padding:14px 28px;border-radius:var(--r-btn);font-size:15px;font-weight:600;display:flex;align-items:center;gap:9px;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);}
.btn-hero-primary:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(58,92,67,.28);}
.btn-hero-secondary{background:var(--brown);color:#fff;padding:14px 28px;border-radius:var(--r-btn);font-size:15px;font-weight:600;display:flex;align-items:center;gap:9px;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);}
.btn-hero-secondary:hover{background:var(--brown-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(122,64,40,.28);}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px;animation:fadeUp .55s .2s ease both;}
.trust-item{display:flex;align-items:center;gap:6px;background:var(--warm-white);border:1px solid var(--border);border-radius:40px;padding:6px 14px;font-size:12.5px;color:var(--text-mid);font-weight:500;white-space:nowrap;}
.trust-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;}
.hero-right{animation:fadeUp .6s .2s ease both;position:relative;}
.hero-visual-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;gap:14px;}
.hero-img-cell{border-radius:var(--r-card);overflow:hidden;position:relative;}
.hero-img-cell:first-child{grid-row:span 2;border-radius:28px;}
.hero-img-cell img{height:100%;width:100%;object-fit:cover;}
.hero-img-badge{position:absolute;bottom:14px;left:14px;background:rgba(248,243,232,.92);backdrop-filter:blur(8px);border-radius:10px;padding:8px 12px;font-size:12px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;box-shadow:var(--shadow-sm);}
.hero-float-stat{position:absolute;top:-20px;right:-20px;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-md);text-align:center;animation:float 3s ease-in-out infinite;z-index:10;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.float-num{font-family:'Lora',serif;font-size:28px;font-weight:700;color:var(--green);line-height:1;}
.float-label{font-size:11px;color:var(--text-light);margin-top:3px;}
.hero-bottom-strip{background:var(--green);margin-top:0;padding:0 60px;display:grid;grid-template-columns:repeat(4,1fr);}
.strip-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.9);font-size:13px;font-weight:500;padding:18px 20px;border-right:1px solid rgba(255,255,255,.1);}
.strip-item:last-child{border-right:none;}
.strip-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}

/* PAGE WRAP */
.page-wrap{max-width:1160px;margin:0 auto;padding:60px 48px 100px;}
.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:20px;}
.page-eyebrow{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:8px;}
.page-title{font-family:'Lora',serif;font-size:38px;font-weight:700;color:var(--text);line-height:1.15;}
.page-title em{font-style:italic;color:var(--green);}
.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px;}
.pill{background:none;border:1.5px solid var(--border);border-radius:40px;padding:7px 18px;font-size:13px;font-weight:500;color:var(--text-mid);transition:all var(--transition);}
.pill:hover{border-color:var(--green);color:var(--green);}
.pill.on{background:var(--green);border-color:var(--green);color:#fff;}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px;}
.card{background:var(--warm-white);border-radius:var(--r-card);overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(58,92,67,.2);}
.card-badge{position:absolute;top:14px;left:14px;z-index:2;background:var(--green);color:#fff;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:20px;}
.card-badge.gold{background:var(--gold);color:var(--text);}
.card-badge.rust{background:var(--brown);}
.card-img-wrap{position:relative;height:210px;overflow:hidden;}
.card-img-wrap img{height:100%;transition:transform .5s ease;}
.card:hover .card-img-wrap img{transform:scale(1.04);}
.card-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.card-cat{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green);}
.card-stars{font-size:12px;color:var(--gold);font-weight:600;}
.card-stars span{color:var(--text-light);font-weight:400;}
.card-title{font-family:'Lora',serif;font-size:19px;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.28;}
.card-desc{font-size:13.5px;color:var(--text-mid);line-height:1.62;margin-bottom:16px;flex:1;}
.card-includes{background:var(--cream);border-radius:10px;padding:12px 14px;margin-bottom:16px;display:flex;flex-direction:column;gap:6px;}
.include-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-mid);}
.include-icon{width:22px;height:22px;border-radius:6px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;}
.card-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:18px;}
.tag{background:var(--green-pale);color:var(--green);border:1px solid rgba(58,92,67,.15);border-radius:20px;padding:3px 9px;font-size:11px;font-weight:500;}
.tag.brown{background:var(--brown-pale);color:var(--brown);border-color:rgba(122,64,40,.15);}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--border);}
.price-label{font-size:11px;color:var(--text-light);letter-spacing:.04em;}
.price-val{font-family:'Lora',serif;font-size:26px;font-weight:700;color:var(--text);line-height:1;}
.price-val sup{font-size:14px;vertical-align:super;font-family:'DM Sans',sans-serif;}
.price-note{font-size:11px;color:var(--text-light);}
.btn-card{background:var(--green);color:#fff;padding:10px 18px;border-radius:10px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);}
.btn-card:hover{background:var(--green-dark);transform:scale(1.03);box-shadow:0 6px 18px rgba(58,92,67,.26);}
.btn-card:active{transform:scale(.97);}
.btn-card.brown-btn{background:var(--brown);}
.btn-card.brown-btn:hover{background:var(--brown-dark);box-shadow:0 6px 18px rgba(122,64,40,.28);}
.btn-card.added{background:var(--gold);color:var(--text);}

/* BYO BANNER */
.byo-banner{background:var(--green);border-radius:24px;padding:50px 56px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;overflow:hidden;position:relative;margin-top:12px;}
.byo-banner::before{content:'';position:absolute;top:-80px;right:160px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.05);}
.byo-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:10px;}
.byo-title{font-family:'Lora',serif;font-size:32px;font-weight:700;color:#fff;line-height:1.15;margin-bottom:12px;}
.byo-title em{font-style:italic;color:var(--gold);}
.byo-desc{font-size:14px;color:rgba(255,255,255,.7);line-height:1.65;max-width:480px;}
.byo-reqs{display:flex;gap:14px;margin-top:22px;}
.byo-req{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 16px;text-align:center;}
.byo-req-n{font-family:'Lora',serif;font-size:24px;font-weight:700;color:var(--gold);line-height:1;}
.byo-req-l{font-size:10px;color:rgba(255,255,255,.5);margin-top:3px;}
.btn-byo{background:var(--gold);color:var(--text);padding:16px 30px;border-radius:14px;font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px;white-space:nowrap;position:relative;z-index:1;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);flex-shrink:0;}
.btn-byo:hover{background:#d8a848;transform:translateY(-2px);box-shadow:0 10px 30px rgba(200,151,58,.4);}

/* CATERING HERO */
.catering-hero{background:var(--brown);border-radius:24px;overflow:hidden;padding:56px 60px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-bottom:48px;position:relative;}
.catering-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.1) 0%,transparent 60%);}
.catering-hero-text{position:relative;z-index:1;}
.catering-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:12px;}
.catering-hero-title{font-family:'Lora',serif;font-size:36px;font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px;}
.catering-hero-title em{font-style:italic;color:#F5C87A;}
.catering-hero-desc{font-size:14px;color:rgba(255,255,255,.72);line-height:1.7;margin-bottom:24px;}
.catering-callout-btn{background:#fff;color:var(--brown);padding:12px 24px;border-radius:10px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:background var(--transition),transform var(--transition);}
.catering-callout-btn:hover{background:var(--cream);transform:translateY(-1px);}
.catering-hero-stats{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.catering-stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:18px;}
.catering-stat-n{font-family:'Lora',serif;font-size:30px;font-weight:700;color:#F5C87A;line-height:1;}
.catering-stat-l{font-size:12px;color:rgba(255,255,255,.6);margin-top:4px;}

/* TOAST */
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(90px);background:var(--green);color:#fff;padding:13px 22px;border-radius:40px;font-size:13.5px;font-weight:600;box-shadow:0 10px 36px rgba(58,92,67,.38);transition:transform .4s cubic-bezier(.34,1.56,.64,1);z-index:500;white-space:nowrap;display:flex;align-items:center;gap:9px;}
.toast.show{transform:translateX(-50%) translateY(0);}

/* CART DRAWER */
.cart-overlay{position:fixed;inset:0;background:rgba(30,42,34,.45);backdrop-filter:blur(4px);z-index:300;opacity:0;pointer-events:none;transition:opacity var(--transition);}
.cart-overlay.open{opacity:1;pointer-events:all;}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:360px;background:var(--warm-white);z-index:301;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-20px 0 60px rgba(30,42,34,.15);}
.cart-drawer.open{transform:translateX(0);}
.drawer-head{padding:24px 24px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.drawer-title{font-family:'Lora',serif;font-size:22px;font-weight:700;}
.drawer-close{width:36px;height:36px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-mid);transition:background var(--transition);}
.drawer-close:hover{background:var(--cream-dark);}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px;}
.drawer-empty{text-align:center;padding:60px 20px;color:var(--text-light);font-size:14px;}
.drawer-empty-icon{font-size:48px;margin-bottom:12px;}
.cart-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border);}
.cart-item-icon{width:48px;height:48px;border-radius:10px;background:var(--green-pale);font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cart-item-info{flex:1;}
.cart-item-name{font-size:14px;font-weight:600;margin-bottom:3px;}
.cart-item-price{font-size:13px;color:var(--text-light);}
.cart-item-remove{background:none;font-size:18px;color:var(--text-light);padding:0 4px;transition:color var(--transition);}
.cart-item-remove:hover{color:var(--brown);}
.drawer-footer{padding:20px 24px;border-top:1px solid var(--border);}
.drawer-subtotal{display:flex;justify-content:space-between;font-size:15px;font-weight:600;margin-bottom:16px;}
.btn-checkout{width:100%;background:var(--green);color:#fff;padding:15px;border-radius:12px;font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background var(--transition),box-shadow var(--transition);}
.btn-checkout:hover{background:var(--green-dark);box-shadow:0 8px 24px rgba(58,92,67,.28);}

/* BUILD YOUR OWN MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(30,42,34,.5);backdrop-filter:blur(6px);z-index:400;opacity:0;pointer-events:none;transition:opacity var(--transition);display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--warm-white);border-radius:24px;width:100%;max-width:680px;max-height:88vh;overflow-y:auto;transform:scale(.94) translateY(20px);transition:transform .35s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-lg);}
.modal-overlay.open .modal{transform:scale(1) translateY(0);}
.modal-head{padding:32px 36px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;position:sticky;top:0;background:var(--warm-white);z-index:1;border-radius:24px 24px 0 0;}
.modal-title{font-family:'Lora',serif;font-size:26px;font-weight:700;line-height:1.2;}
.modal-sub{font-size:13px;color:var(--text-light);margin-top:4px;}
.modal-close{width:36px;height:36px;border-radius:50%;background:var(--cream);font-size:20px;color:var(--text-mid);display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0;}
.modal-close:hover{background:var(--cream-dark);}
.modal-body{padding:24px 36px;}
.builder-section{margin-bottom:28px;}
.builder-section-title{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mid);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.builder-options{display:flex;gap:8px;flex-wrap:wrap;}
.builder-opt{background:none;border:1.5px solid var(--border);border-radius:10px;padding:9px 16px;font-size:13px;font-weight:500;color:var(--text-mid);transition:all var(--transition);}
.builder-opt:hover{border-color:var(--green);color:var(--green);}
.builder-opt.sel{background:var(--green-pale);border-color:var(--green);color:var(--green);font-weight:600;}
.modal-footer{padding:20px 36px 28px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.modal-pack-info{font-size:13px;color:var(--text-light);}
.modal-pack-info strong{font-family:'Lora',serif;font-size:22px;color:var(--green);font-weight:700;}
.btn-modal-add{background:var(--green);color:#fff;padding:13px 24px;border-radius:12px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);}
.btn-modal-add:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 8px 20px rgba(58,92,67,.28);}

/* FOOTER */
footer{background:var(--text);padding:60px 48px 32px;margin-top:0;}
footer .footer-brand-name img{mix-blend-mode:screen;border-radius:6px;}
.footer-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand-name{font-family:'Lora',serif;font-size:18px;font-weight:700;color:#fff;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.footer-brand-desc{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;max-width:260px;margin-bottom:20px;}
.footer-social{display:flex;gap:10px;}
.social-btn{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background var(--transition),color var(--transition);}
.social-btn:hover{background:var(--green);color:#fff;}
.footer-col-title{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:14px;color:rgba(255,255,255,.6);text-decoration:none;transition:color var(--transition);}
.footer-links a:hover{color:#fff;}
.footer-bottom{max-width:1160px;margin:0 auto;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-copy{font-size:13px;color:rgba(255,255,255,.35);}
.footer-legal{display:flex;gap:20px;align-items:center;}
.footer-legal a{font-size:13px;color:rgba(255,255,255,.35);text-decoration:none;}
.footer-legal a:hover{color:rgba(255,255,255,.7);}

/* ═══════════════════════════════════════
   Animations & Reveal
═══════════════════════════════════════ */

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease;}
.reveal.in{opacity:1;transform:none;}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}

/* ═══════════════════════════════════════════════
   MEAL PREP PAGE — TMC STYLE
═══════════════════════════════════════════════ */

/* HERO */
.mp-hero{position:relative;overflow:hidden;padding:80px 48px;background:#fff;border-bottom:1px solid var(--border);text-align:center;}
.mp-hero-blob{position:absolute;border-radius:50%;pointer-events:none;}
.mp-hero-blob-1{width:320px;height:320px;background:var(--green-pale);top:-120px;left:-80px;}
.mp-hero-blob-2{width:260px;height:260px;background:var(--gold);opacity:.08;bottom:-90px;right:-60px;}
.mp-hero-blob-3{width:180px;height:180px;background:var(--green-pale);bottom:-60px;left:40%;}
.mp-hero-content{position:relative;z-index:1;max-width:700px;margin:0 auto;}
.mp-hero-h2{font-family:'Lora',serif;font-size:clamp(22px,3.2vw,34px);font-weight:700;color:var(--text);line-height:1.22;margin-bottom:16px;}
.mp-hero-h2 em{font-style:italic;color:var(--green);}
.mp-hero-sub{font-size:15px;color:var(--text-mid);line-height:1.7;max-width:580px;margin:0 auto;}

/* DELIVERY BAR */
.mp-delivery-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 48px;background:#fff;border-bottom:1px solid var(--border);gap:20px;}
.mp-delivery-left{display:flex;align-items:center;gap:14px;}
.mp-delivery-icon-box{width:42px;height:42px;border-radius:10px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--green);flex-shrink:0;}
.mp-delivery-title{font-size:14px;font-weight:700;color:var(--text);}
.mp-delivery-sub{font-size:12.5px;color:var(--text-mid);margin-top:2px;}
.mp-delivery-btn{padding:8px 18px;border-radius:8px;border:1.5px solid var(--text);font-size:13px;font-weight:600;color:var(--text);background:#fff;transition:all var(--transition);white-space:nowrap;}
.mp-delivery-btn:hover{background:var(--text);color:#fff;}

/* LAYOUT */
.mp-layout{display:grid;grid-template-columns:260px 1fr;border-top:1px solid var(--border);background:var(--cream);}

/* SIDEBAR */
.mp-sidebar{background:#fff;border-right:1px solid var(--border);}
.mp-cat-list{padding:8px 0 0;}
.mp-cat-btn{display:block;width:100%;text-align:left;padding:13px 24px;font-size:14px;font-weight:500;color:var(--text-mid);background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:all var(--transition);}
.mp-cat-btn:hover{color:var(--green);background:var(--green-pale);}
.mp-cat-btn.active{color:var(--text);font-weight:700;border-left:3px solid var(--green);padding-left:21px;}
.mp-filter-group{padding:20px 24px;border-bottom:1px solid var(--border);}
.mp-filter-group-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:12px;}
.mp-filter-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;cursor:pointer;gap:8px;}
.mp-filter-row:hover .mp-filter-name{color:var(--green);}
.mp-filter-name{font-size:13.5px;color:var(--text);transition:color var(--transition);flex:1;}
.mp-filter-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.mp-filter-count{font-size:12px;color:var(--text-light);min-width:16px;text-align:right;}
.mp-filter-cb{width:15px;height:15px;accent-color:var(--green);cursor:pointer;flex-shrink:0;}

/* CONTENT */
.mp-content{padding:24px 28px;background:var(--cream);}
.mp-sort-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;}
.mp-sort-title{font-family:'Lora',serif;font-size:20px;font-weight:700;color:var(--text);}
.mp-sort-select{padding:7px 14px;border-radius:8px;border:1.5px solid var(--border);font-size:13px;font-weight:500;color:var(--text);background:#fff;cursor:pointer;appearance:auto;}

/* CATEGORY HERO BANNER */
.mp-cat-hero{display:grid;grid-template-columns:1fr 1fr;border-radius:14px;overflow:hidden;margin-bottom:20px;min-height:185px;border:1px solid var(--border);}
.mp-cat-hero-img{width:100%;height:100%;object-fit:cover;display:block;}
.mp-cat-hero-text{background:var(--green);padding:28px 26px;display:flex;flex-direction:column;justify-content:center;}
.mp-cat-hero-text h3{font-family:'Lora',serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.25;}
.mp-cat-hero-text p{font-size:12.5px;color:rgba(255,255,255,.75);line-height:1.62;}

/* PRODUCT GRID */
.mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}

/* MP CARD */
.mp-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);cursor:pointer;}
.mp-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(30,42,34,.12);border-color:rgba(58,92,67,.2);}
.mp-card-img-wrap{position:relative;height:170px;overflow:hidden;flex-shrink:0;}
.mp-card-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.mp-card:hover .mp-card-img-wrap img{transform:scale(1.06);}
.mp-card-badge-wrap{position:absolute;top:8px;left:8px;z-index:2;}
.mp-card-badge{display:inline-flex;align-items:center;gap:5px;background:var(--gold);color:var(--text);font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:4px 8px;border-radius:20px;}
.mp-card-body{padding:12px 14px;flex:1;display:flex;flex-direction:column;}
.mp-card-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:10px;flex:1;}
.mp-card-footer{display:flex;align-items:center;justify-content:space-between;gap:6px;}
.mp-card-prices{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;}
.mp-price-sub{display:flex;align-items:center;gap:3px;font-size:13px;font-weight:700;color:var(--green);}
.mp-price-sub svg{flex-shrink:0;}
.mp-price-orig{font-size:11.5px;color:var(--text-light);text-decoration:line-through;}
.mp-price-soldout{font-size:12px;color:var(--text-light);font-style:italic;}
.mp-card-plus{width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);flex-shrink:0;}
.mp-card-plus:hover:not(:disabled){background:var(--green-dark);transform:scale(1.1);box-shadow:0 4px 14px rgba(58,92,67,.32);}
.mp-card.mp-sold-out{opacity:.65;}

/* FULFILLMENT MODAL */
.mp-fulfill-overlay{position:fixed;inset:0;background:rgba(30,42,34,.45);backdrop-filter:blur(4px);z-index:400;display:none;align-items:center;justify-content:center;padding:20px;}
.mp-fulfill-overlay.open{display:flex;}
.mp-fulfill-modal{background:#fff;border-radius:20px;width:min(520px,100%);max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);padding:28px;}
.mp-fulfill-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.mp-fulfill-head h3{font-family:'Lora',serif;font-size:20px;font-weight:700;color:var(--text);}
.mp-fulfill-close{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-mid);cursor:pointer;background:none;transition:all var(--transition);}
.mp-fulfill-close:hover{background:var(--cream);}
.mp-fulfill-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:7px;}
.mp-fulfill-input{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);margin-bottom:15px;transition:border-color var(--transition);box-sizing:border-box;font-family:inherit;}
.mp-fulfill-input:focus{outline:none;border-color:var(--green);}
.mp-fulfill-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px;}
.mp-toggle-btn{padding:12px;border-radius:10px;font-size:13px;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--text-mid);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:all var(--transition);}
.mp-toggle-btn.active{background:var(--green);border-color:var(--green);color:#fff;}
.mp-fulfill-date-box{padding:12px 16px;border:1.5px solid var(--green);border-radius:10px;font-size:14px;color:var(--text);font-weight:600;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.mp-fulfill-login-banner{background:var(--green);border-radius:12px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;}
.mp-fulfill-login-text strong{display:block;color:#fff;font-size:13.5px;font-weight:700;margin-bottom:2px;}
.mp-fulfill-login-text span{color:rgba(255,255,255,.78);font-size:12.5px;}
.mp-fulfill-login-btn2{background:#fff;color:var(--green);padding:8px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:none;white-space:nowrap;transition:all var(--transition);}
.mp-fulfill-login-btn2:hover{background:var(--cream);}
.mp-fulfill-sub-row{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;margin-bottom:4px;}
.mp-fulfill-sub-row input{margin-top:2px;width:16px;height:16px;flex-shrink:0;accent-color:var(--green);}
.mp-fulfill-sub-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px;}
.mp-fulfill-sub-desc{font-size:11.5px;color:var(--text-mid);line-height:1.5;}
.mp-fulfill-footer{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px;}
.mp-fulfill-cancel{padding:12px;border-radius:10px;border:1.5px solid var(--border);font-size:14px;font-weight:600;color:var(--text);background:#fff;cursor:pointer;transition:all var(--transition);}
.mp-fulfill-cancel:hover{background:var(--cream);}
.mp-fulfill-start{padding:12px;border-radius:10px;background:var(--green);font-size:14px;font-weight:700;color:#fff;cursor:pointer;border:none;transition:background var(--transition);}
.mp-fulfill-start:hover{background:var(--green-dark);}

/* PRODUCT DETAIL MODAL */
.mp-prod-overlay{position:fixed;inset:0;background:rgba(30,42,34,.45);backdrop-filter:blur(4px);z-index:400;display:none;align-items:center;justify-content:center;padding:20px;}
.mp-prod-overlay.open{display:flex;}
.mp-prod-modal{background:#fff;border-radius:20px;width:min(540px,100%);max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);display:flex;flex-direction:column;}
.mp-prod-head{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 0;gap:12px;}
.mp-prod-title{font-family:'Lora',serif;font-size:20px;font-weight:700;color:var(--text);line-height:1.22;}
.mp-prod-close{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-mid);cursor:pointer;background:none;transition:all var(--transition);flex-shrink:0;}
.mp-prod-close:hover{background:var(--cream);}
.mp-prod-body{padding:16px 24px;flex:1;}
.mp-prod-desc{font-size:13px;color:var(--text-mid);line-height:1.65;margin-bottom:16px;}
.mp-prod-includes{background:var(--cream);border-radius:10px;padding:12px 14px;margin-bottom:16px;display:flex;flex-direction:column;gap:5px;}
.mp-prod-qty-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border:1.5px solid var(--border);border-radius:10px;margin-bottom:14px;}
.mp-prod-qty-label{font-size:14px;font-weight:600;color:var(--text);}
.mp-qty-ctrl{display:flex;align-items:center;gap:16px;}
.mp-qty-btn{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--green);color:var(--green);background:#fff;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);}
.mp-qty-btn:hover{background:var(--green);color:#fff;}
.mp-qty-val{font-size:16px;font-weight:700;color:var(--text);min-width:24px;text-align:center;}
.mp-prod-summary{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:4px;}
.mp-prod-summary-row{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;font-size:13px;}
.mp-prod-summary-row+.mp-prod-summary-row{border-top:1px solid var(--border);}
.mp-sum-label{color:var(--text-mid);}
.mp-sum-price{font-weight:600;color:var(--text);}
.mp-prod-summary-row:last-child .mp-sum-label{font-weight:700;color:var(--text);}
.mp-prod-summary-row:last-child .mp-sum-price{font-weight:700;color:var(--green);font-size:14.5px;}
.mp-prod-footer{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 24px 20px;border-top:1px solid var(--border);}
.mp-prod-cancel{padding:12px;border-radius:10px;border:1.5px solid var(--border);font-size:14px;font-weight:600;color:var(--text);background:#fff;cursor:pointer;transition:all var(--transition);}
.mp-prod-cancel:hover{background:var(--cream);}
.mp-prod-add{padding:12px;border-radius:10px;background:var(--green);font-size:14px;font-weight:700;color:#fff;cursor:pointer;border:none;transition:background var(--transition);}
.mp-prod-add:hover{background:var(--green-dark);}

/* RESPONSIVE — MP */
@media(max-width:960px){
  .mp-layout{grid-template-columns:220px 1fr;}
  .mp-content{padding:20px 18px;}
  .mp-grid{grid-template-columns:repeat(2,1fr);}
  .mp-delivery-bar{padding:12px 20px;}
  .mp-hero{padding:52px 24px;}
}
@media(max-width:768px){
  .mp-layout{grid-template-columns:1fr;}
  .mp-sidebar{border-right:none;border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:0;}
  .mp-cat-list{border-right:1px solid var(--border);}
  .mp-cat-hero{grid-template-columns:1fr;min-height:auto;}
  .mp-cat-hero-img{height:140px;}
}
@media(max-width:520px){
  .mp-hero{padding:36px 18px;}
  .mp-hero-h2{font-size:20px;}
  .mp-delivery-bar{padding:10px 16px;}
  .mp-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .mp-card-img-wrap{height:140px;}
  .mp-card-body{padding:10px 12px;}
  .mp-card-name{font-size:12px;}
  .mp-sidebar{display:block;}
}
