/* ==============================================
   COVATA BUNICII SHOP - CSS
   Colors preserved from original design
   ============================================== */
:root {
  --bg: #f5f2ed;
  --ink: #2b2b2b;
  --brand: #6b4e2e;
  --paper: #fffaf2;
  --brand-10: rgba(107,78,46,.10);
  --brand-18: rgba(107,78,46,.18);
  --brand-30: rgba(107,78,46,.30);
  --shadow: 0 10px 30px rgba(43,43,43,.10);
  --radius: 16px;
  --radius-sm: 10px;
  --success: #10b981;
  --danger: #ef4444;
  --warning: #f59e0b;
  --info: #3b82f6;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,'Apple Color Emoji','Segoe UI Emoji';background:var(--bg);color:var(--ink);line-height:1.6}
a{color:inherit}
img{max-width:100%;height:auto}

/* --- HEADER --- */
.site-header{background:rgba(245,242,237,.98);border-bottom:1px solid rgba(43,43,43,.08)}
.header-inner{max-width:1100px;margin:0 auto;padding:14px 16px;display:flex;gap:14px;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.logo{width:220px;max-width:48vw;display:block;height:auto}
.header-actions{display:flex;align-items:center;gap:14px}

/* Cart icon */
.cart-link{position:relative;display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--paper);border:1px solid var(--brand-18);color:var(--brand);text-decoration:none;transition:all .15s}
.cart-link:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(43,43,43,.10)}
.cart-badge{position:absolute;top:-4px;right:-4px;background:var(--brand);color:#fff;font-size:11px;font-weight:800;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}

/* Cart hover dropdown - see navbar section */

/* Language selector */
.lang-select{position:relative;display:flex;align-items:center;justify-content:flex-end}
.lang-trigger{appearance:none;background:var(--paper);border:1px solid var(--brand-18);color:var(--ink);padding:10px 40px 10px 44px;border-radius:999px;font-weight:700;line-height:1;box-shadow:0 8px 18px rgba(43,43,43,.06);cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.lang-trigger:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.lang-select::before{content:"";position:absolute;left:14px;width:22px;height:16px;border-radius:3px;background-size:cover;background-position:center;box-shadow:0 2px 6px rgba(43,43,43,.18);pointer-events:none}
.lang-select[data-flag="ro"]::before{background-image:url("/assets/flags/ro.png")}
.lang-select[data-flag="hu"]::before{background-image:url("/assets/flags/hu.png")}
.lang-select[data-flag="en"]::before{background-image:url("/assets/flags/en.png")}
.lang-select::after{content:"▾";position:absolute;right:14px;pointer-events:none;color:var(--brand);font-weight:900;transform:translateY(-1px)}
.lang-select[data-lang-dropdown] .lang-menu{position:absolute;top:calc(100% + 10px);right:0;background:var(--paper);border:1px solid var(--brand-18);border-radius:18px;box-shadow:0 18px 40px rgba(43,43,43,.14);padding:8px;margin:0;list-style:none;min-width:160px;z-index:300}
.lang-select[data-lang-dropdown] .lang-menu[hidden]{display:none}
.lang-menu{display:block}.lang-menu[hidden]{display:none !important}.lang-select.is-open .lang-menu{display:block !important}
.lang-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;color:var(--ink);text-decoration:none;font-weight:700;line-height:1}
.lang-option:hover,.lang-option:focus-visible{background:rgba(107,78,46,.10);outline:none}
.lang-option[aria-selected="true"]{background:rgba(107,78,46,.16)}
.lang-flag{display:block;width:22px;height:16px;border-radius:3px;box-shadow:0 2px 6px rgba(43,43,43,.18)}

/* --- NAVBAR --- */
.navbar{background:var(--brand);position:sticky;top:0;z-index:100}
.nav-wrap{max-width:1100px;margin:0 auto;padding:8px 10px;display:flex;align-items:center;gap:10px}
.nav-inner{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:0;max-width:none;margin:0;flex:1}
.nav-inner a{color:#fff;text-decoration:none;font-weight:700;padding:10px 14px;border-radius:999px;transition:background .12s,transform .12s}
.nav-inner a:hover{background:rgba(255,255,255,.16)}
.nav-inner a:active{transform:translateY(1px)}
.nav-inner a.current{background:rgba(255,255,255,.20)}
.nav-toggle{display:none;align-items:center;gap:10px;background:transparent;border:1px solid rgba(255,255,255,.28);color:#fff;padding:10px 12px;border-radius:999px;cursor:pointer;font-weight:800}
.nav-toggle-icon{width:18px;height:12px;position:relative;display:inline-block}
.nav-toggle-icon::before,.nav-toggle-icon::after{content:"";position:absolute;left:0;right:0;height:2px;background:#fff;border-radius:2px}
.nav-toggle-icon::before{top:0;box-shadow:0 5px 0 #fff}
.nav-toggle-icon::after{bottom:0}
.nav-actions{display:none;align-items:center;gap:8px}
.cart-link-nav{width:36px;height:36px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;text-decoration:none}
.cart-link-nav:hover{background:rgba(255,255,255,.22);transform:none;box-shadow:none}
.cart-link-nav .cart-badge{top:-4px;right:-4px;border-color:var(--brand)}
.nav-only.account-link{width:36px;height:36px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:50%;text-decoration:none}
.nav-only.account-link:hover{background:rgba(255,255,255,.22)}
.nav-only.account-link.logged-in{background:rgba(255,255,255,.25)}

/* Cart hover dropdown (header) */
.cart-wrapper{position:relative}
.cart-hover-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--paper);border:1px solid rgba(43,43,43,.1);border-radius:var(--radius);box-shadow:0 16px 40px rgba(43,43,43,.18);padding:14px;z-index:200}
.cart-wrapper:hover .cart-hover-dropdown{display:block}
.cart-hover-item{display:flex;align-items:center;gap:6px;padding:6px 0;font-size:13px;border-bottom:1px solid rgba(43,43,43,.06)}
.cart-hover-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}
.cart-hover-name small{color:rgba(43,43,43,.5)}
.cart-hover-qty{color:rgba(43,43,43,.5);font-size:12px;white-space:nowrap}
.cart-hover-price{font-weight:700;white-space:nowrap;color:var(--ink)}
.cart-hover-total{display:flex;justify-content:space-between;padding:10px 0 8px;margin-top:4px;border-top:2px solid rgba(43,43,43,.1);font-size:15px;color:var(--brand)}

/* Scroll to top */
.scroll-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;font-size:20px;font-weight:800;border:none;cursor:pointer;box-shadow:0 4px 16px rgba(43,43,43,.2);z-index:90;opacity:0;pointer-events:none;transition:all .25s;display:flex;align-items:center;justify-content:center}
.scroll-top.visible{opacity:1;pointer-events:auto}
.scroll-top:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(43,43,43,.25)}

/* --- MAIN --- */
main{max-width:1100px;margin:18px auto 28px;padding:0 16px}

/* --- FREE SHIPPING BANNER --- */
.free-shipping-banner{text-align:center;padding:8px 16px;background:var(--brand-10);border:1px solid var(--brand-30);border-radius:var(--radius);margin-bottom:16px;font-weight:600;font-size:14px;color:var(--brand)}

/* --- CARDS --- */
.card{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(43,43,43,.08);padding:22px}

/* --- HERO --- */
.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:center}
.hero h1{margin:0 0 10px;font-size:clamp(28px,3.5vw,44px);line-height:1.1;letter-spacing:-.02em}
.hero-subtitle{margin:0 0 16px;font-size:clamp(15px,1.6vw,18px);color:rgba(43,43,43,.85)}
.hero-image img{border-radius:var(--radius);width:100%;object-fit:cover;max-height:350px}
.hero-placeholder{display:flex;align-items:center;justify-content:center}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:var(--brand-10);border:1px solid var(--brand-30);font-weight:650;font-size:14px}

/* --- BUTTONS --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:999px;font-weight:700;text-decoration:none;border:none;cursor:pointer;font-size:14px;transition:all .15s}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:#5a3f24;transform:translateY(-1px);box-shadow:0 6px 18px rgba(43,43,43,.15)}
.btn-outline{background:transparent;border:2px solid var(--brand);color:var(--brand)}
.btn-outline:hover{background:var(--brand-10)}
.btn-sm{padding:6px 14px;font-size:13px}
.btn-lg{padding:14px 28px;font-size:16px}
.btn-block{width:100%;text-align:center;margin-top:10px}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#dc2626}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#059669}

/* --- GRID --- */
.grid{display:grid;gap:16px}
.product-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}

/* --- PRODUCT CARDS --- */
.product-card{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(43,43,43,.08);overflow:hidden;transition:transform .2s,box-shadow .2s}
.product-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(43,43,43,.14)}
.product-card-image{display:block;aspect-ratio:4/3;overflow:hidden;background:var(--bg)}
.product-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.product-card:hover .product-card-image img{transform:scale(1.05)}
.product-card-body{padding:16px}
.product-card-body h3{margin:0 0 6px;font-size:16px}
.product-card-body h3 a{text-decoration:none}
.product-desc{margin:0 0 10px;color:rgba(43,43,43,.78);font-size:14px}
.product-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.product-price{font-weight:800;font-size:18px;color:var(--brand)}
.stock-badge{font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px}
.stock-badge.in-stock{background:rgba(16,185,129,.12);color:#059669}
.stock-badge.out-of-stock{background:rgba(239,68,68,.12);color:#dc2626}

/* --- SECTION TITLE --- */
.section-title{margin:0 0 18px;font-size:22px;letter-spacing:-.01em}
.section-products{margin-top:24px}
.section-products .section-title{margin-bottom:16px}

/* --- BREADCRUMBS --- */
.breadcrumbs{margin-bottom:16px;font-size:14px;color:rgba(43,43,43,.6)}
.breadcrumbs a{text-decoration:none;color:var(--brand)}
.breadcrumbs a:hover{text-decoration:underline}

/* --- PRODUCT DETAIL --- */
.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.product-gallery{}
.product-main-image{border-radius:var(--radius);overflow:hidden;background:var(--bg)}
.product-main-image img{width:100%;aspect-ratio:1;object-fit:cover}
.product-thumbnails{display:flex;gap:8px;margin-top:10px}
.thumb{width:60px;height:60px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;cursor:pointer;padding:0;background:none}
.thumb.active{border-color:var(--brand)}
.thumb img{width:100%;height:100%;object-fit:cover}
.product-info h1{margin:0 0 10px;font-size:28px}
.product-short-desc{color:rgba(43,43,43,.78);margin:0 0 20px}
.product-price-display{margin:16px 0;display:flex;align-items:baseline;gap:10px}
.current-price{font-size:28px;font-weight:800;color:var(--brand)}
.tax-info{font-size:13px;color:rgba(43,43,43,.5)}

/* Variations */
.variation-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.variation-option{display:flex;align-items:center;gap:8px;padding:10px 16px;border:2px solid rgba(43,43,43,.12);border-radius:var(--radius-sm);cursor:pointer;transition:all .12s;background:var(--paper)}
.variation-option.selected{border-color:var(--brand);background:var(--brand-10)}
.variation-option.out-of-stock{opacity:.5;cursor:not-allowed}
.variation-option input{display:none}
.variation-label{font-weight:700}
.variation-price{font-weight:600;color:var(--brand)}
.variation-oos{font-size:12px;color:var(--danger)}

/* Quantity */
.qty-group label{font-weight:700;margin-bottom:6px;display:block}
.qty-control{display:inline-flex;align-items:center;border:2px solid rgba(43,43,43,.12);border-radius:var(--radius-sm);overflow:hidden}
.qty-btn{width:38px;height:38px;border:none;background:var(--bg);cursor:pointer;font-size:18px;font-weight:700;color:var(--ink);display:flex;align-items:center;justify-content:center}
.qty-btn:hover{background:var(--brand-10)}
.qty-control input[type="number"]{width:50px;height:38px;border:none;text-align:center;font-size:16px;font-weight:700;-moz-appearance:textfield;background:transparent}
.qty-control input::-webkit-outer-spin-button,.qty-control input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.btn-add-cart{width:100%;margin-top:16px}

/* Product description */
.product-description{margin-top:30px;padding-top:24px;border-top:1px solid rgba(43,43,43,.08)}
.product-description h2{margin:0 0 12px}
.prose{line-height:1.7}
.prose h2,.prose h3{margin:20px 0 8px}
.prose p{margin:0 0 12px}
.prose dl{display:grid;grid-template-columns:160px 1fr;gap:10px 14px}
.prose dt{font-weight:800}
.prose dd{margin:0}

/* --- CART --- */
.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-item{display:grid;grid-template-columns:70px 1fr auto auto;gap:14px;align-items:center;padding:14px;border-radius:var(--radius-sm);border:1px solid rgba(43,43,43,.08);background:rgba(255,255,255,.4)}
.cart-item-image{width:70px;height:70px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg)}
.cart-item-image img{width:100%;height:100%;object-fit:cover}
.cart-item-info h3{margin:0 0 4px;font-size:15px}
.cart-item-info h3 a{text-decoration:none}
.cart-variation{font-size:13px;color:rgba(43,43,43,.6);display:block}
.cart-item-price{font-size:14px;color:rgba(43,43,43,.7)}
.cart-item-total{font-weight:800;font-size:16px;color:var(--brand);white-space:nowrap}
.cart-item-actions{display:flex;align-items:center;gap:8px}
.cart-qty-form{margin:0}
.btn-remove{background:none;border:none;cursor:pointer;font-size:18px;color:rgba(43,43,43,.4);padding:4px 8px;border-radius:4px}
.btn-remove:hover{color:var(--danger);background:rgba(239,68,68,.08)}

/* Empty state */
.empty-state{text-align:center;padding:40px 20px}
.empty-icon{font-size:48px;margin-bottom:12px}
.empty-state p{color:rgba(43,43,43,.6);margin-bottom:20px}

/* --- CHECKOUT --- */
.checkout-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.checkout-steps{display:flex;gap:0;margin-bottom:24px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid rgba(43,43,43,.08)}
.checkout-steps .step{flex:1;padding:12px;text-align:center;font-weight:700;font-size:14px;background:var(--bg);color:rgba(43,43,43,.5);transition:all .2s}
.checkout-steps .step.active{background:var(--brand);color:#fff}
.checkout-steps .step span{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.2);font-size:12px;margin-right:6px}

/* Forms */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-weight:700;margin-bottom:4px;font-size:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row:has(> :nth-child(3)){grid-template-columns:1fr 1fr 1fr}
input[type="text"],input[type="email"],input[type="tel"],input[type="number"],input[type="password"],input[type="url"],textarea,select{width:100%;padding:10px 14px;border:2px solid rgba(43,43,43,.12);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;background:var(--paper);transition:border-color .15s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand)}
textarea{resize:vertical}
.checkbox-group{display:flex;align-items:center}
.checkbox-group label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer}
.checkbox-group input[type="checkbox"]{width:18px;height:18px;accent-color:var(--brand)}

/* Option cards (shipping/payment) */
.option-card{display:flex;align-items:flex-start;gap:12px;padding:16px;border:2px solid rgba(43,43,43,.12);border-radius:var(--radius-sm);margin-bottom:10px;cursor:pointer;transition:all .15s}
.option-card.selected{border-color:var(--brand);background:var(--brand-10)}
.option-card input[type="radio"]{margin-top:3px;accent-color:var(--brand)}
.option-card-body{flex:1}
.option-card-body strong{display:block;margin-bottom:2px}
.option-card-body p{margin:0;font-size:13px;color:rgba(43,43,43,.6)}
.option-price{font-weight:800;color:var(--brand);font-size:15px}

.step-nav{display:flex;gap:12px;justify-content:space-between;margin-top:24px}

/* Order summary */
.cart-summary,.checkout-summary{position:sticky;top:60px}
.summary-item{display:flex;justify-content:space-between;gap:10px;padding:6px 0;font-size:14px}
.summary-item-name{flex:1}
.summary-item-name small{display:block;color:rgba(43,43,43,.6)}
.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:15px}
.summary-total{font-weight:800;font-size:18px;border-top:2px solid rgba(43,43,43,.12);padding-top:12px;margin-top:4px}
.summary-total span:last-child{color:var(--brand)}
.checkout-summary h3{margin:0 0 12px}
.checkout-summary hr{border:none;border-top:1px solid rgba(43,43,43,.08);margin:8px 0}

/* Success icon */
.success-icon{width:60px;height:60px;border-radius:50%;background:var(--success);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.order-number{font-size:18px;margin:12px 0}

/* Alerts */
.alert{padding:12px 18px;border-radius:var(--radius-sm);margin-bottom:16px;font-weight:600}
.alert-error{background:rgba(239,68,68,.1);color:#dc2626;border:1px solid rgba(239,68,68,.2)}
.alert-success{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.2)}

/* --- FOOTER --- */
.site-footer{background:var(--paper);border-top:1px solid rgba(43,43,43,.08);margin-top:32px;max-width:1100px;margin-left:auto;margin-right:auto;padding:0 16px}
.newsletter-bar+.site-footer{margin-top:0;border-top:none}
.footer-inner{padding:32px 0 20px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:24px}
.footer-logo{width:140px;margin-bottom:10px}
.footer-tagline{font-size:13px;color:rgba(43,43,43,.6);margin:0}
.footer-col h4{margin:0 0 10px;font-size:15px;color:var(--brand)}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:6px}
.footer-col a{text-decoration:none;font-size:14px;color:rgba(43,43,43,.7)}
.footer-col a:hover{color:var(--brand)}
.footer-contact li{font-size:14px;color:rgba(43,43,43,.7)}
.footer-contact a{color:var(--brand)}
.footer-bottom{padding:16px 0;text-align:center;border-top:1px solid rgba(43,43,43,.08)}
.footer-bottom p{margin:8px 0 0;font-size:13px;color:rgba(43,43,43,.5)}
.trust-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.trust-badge{font-size:13px;font-weight:600;padding:6px 12px;border-radius:999px;background:var(--brand-10);border:1px solid var(--brand-18)}

/* No image placeholder */
.no-image-placeholder{display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--bg);color:rgba(43,43,43,.2)}

/* Out-of-stock badge on product cards */
.product-card-image{position:relative;overflow:hidden}
.product-card-badge{position:absolute;top:10px;left:10px;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:800;z-index:2}
.oos-badge{background:rgba(239,68,68,.9);color:#fff}
.product-oos .product-card-image img{opacity:.5;filter:grayscale(30%)}

/* Catalog/Presentation CTA */
.catalog-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}

/* Out of stock message */
.oos-message{margin-top:16px;padding:16px 20px;background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15);border-radius:14px;color:#b91c1c}
.oos-message p{margin:0 0 6px}
.oos-message p:last-child{margin-bottom:0}
.oos-message a{color:#b91c1c;font-weight:700}

/* --- CONTACT PAGE --- */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:24px}
.contact-info-card{background:var(--warm-bg,#faf6f2);border-radius:16px;padding:28px}
.contact-info-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid rgba(43,43,43,.07)}
.contact-info-item:last-child{border-bottom:none}
.contact-icon{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;flex-shrink:0}
.contact-info-item div{display:flex;flex-direction:column;gap:2px}
.contact-info-item strong{font-size:13px;color:rgba(43,43,43,.5);text-transform:uppercase;letter-spacing:.5px}
.contact-info-item a{color:var(--primary,#5d3916);text-decoration:none;font-weight:600}
.contact-info-item a:hover{text-decoration:underline}
.contact-map{margin-top:24px}
.contact-map h3{margin-bottom:12px;font-size:16px}
.map-container{border-radius:16px;overflow:hidden;border:2px solid rgba(43,43,43,.06)}
.contact-form-side h3{margin-bottom:20px;font-size:18px}
.contact-form .form-group{margin-bottom:16px}
.contact-form label{display:block;font-weight:600;margin-bottom:6px;font-size:14px;color:#2b2b2b}
.contact-form input,.contact-form textarea{width:100%;padding:12px 16px;border:2px solid rgba(43,43,43,.1);border-radius:12px;font-size:15px;font-family:inherit;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--primary,#5d3916);outline:none}
.contact-form .input-error{border-color:#ef4444}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.alert{padding:16px 20px;border-radius:12px;margin-bottom:20px}
.alert-success{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);color:#166534}
.alert-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#991b1b}

/* --- ACCOUNT SYSTEM --- */
.auth-page{display:flex;justify-content:center;padding:20px 0}
.auth-card{max-width:440px;width:100%;text-align:center}
.auth-card h1{margin:0 0 20px;font-size:24px}
.auth-card form{text-align:left}
.auth-icon{margin:0 auto 12px}
.auth-links{margin-top:20px;font-size:14px;color:rgba(43,43,43,.6)}
.auth-links a{color:var(--brand);text-decoration:none}
.auth-links a:hover{text-decoration:underline}
.auth-divider{margin:0 8px}
.auth-card .btn-block{padding:10px 20px;font-size:15px;margin-top:10px;box-sizing:border-box;border:2px solid transparent;line-height:1.5}

/* Account layout */
.account-page{margin-top:0}
.account-layout{display:grid;grid-template-columns:250px 1fr;gap:24px;align-items:start}
.account-content{min-width:0}
.account-content h1{margin:0 0 20px;font-size:24px}

/* Sidebar */
.account-sidebar{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(43,43,43,.08);overflow:hidden;position:sticky;top:60px}
.account-user-card{display:flex;align-items:center;gap:12px;padding:18px;border-bottom:1px solid rgba(43,43,43,.08);background:var(--brand-10)}
.account-avatar{width:40px;height:40px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0}
.account-user-card strong{display:block;font-size:14px}
.account-user-card small{display:block;font-size:12px;color:rgba(43,43,43,.5);word-break:break-all}
.account-nav{display:flex;flex-direction:column;padding:8px}
.account-nav a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;font-size:14px;color:var(--ink);transition:background .12s}
.account-nav a:hover{background:var(--brand-10)}
.account-nav a.active{background:var(--brand);color:#fff}
.account-nav a.active svg{stroke:#fff}
.account-nav-logout{margin-top:4px;border-top:1px solid rgba(43,43,43,.08);padding-top:4px !important;color:var(--danger) !important}

/* Dashboard cards */
.dashboard-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.dash-card{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(43,43,43,.08);padding:20px;text-align:center;text-decoration:none;color:inherit;transition:transform .12s}
a.dash-card:hover{transform:translateY(-2px)}
.dash-card-number{font-size:32px;font-weight:800;color:var(--brand);line-height:1.1}
.dash-card-label{font-size:13px;color:rgba(43,43,43,.6);margin-top:4px;font-weight:600}

/* Section header */
.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.section-header h1,.section-header h2{margin:0}
.account-section .section-header h2{font-size:18px}

/* Orders table */
.orders-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.orders-table{width:100%;border-collapse:collapse;font-size:14px}
.orders-table th{text-align:center;padding:10px 12px;border-bottom:2px solid rgba(43,43,43,.1);font-size:13px;color:rgba(43,43,43,.5);text-transform:uppercase;letter-spacing:.5px}
.orders-table td{padding:12px;border-bottom:1px solid rgba(43,43,43,.06);text-align:center;vertical-align:middle}
.orders-table tbody tr:hover{background:var(--brand-10)}
.orders-table tfoot td{padding:10px 12px;font-size:14px}
.order-total-row td{border-top:2px solid rgba(43,43,43,.12);font-size:16px;color:var(--brand)}

/* Status badges */
.status-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;white-space:nowrap}
.status-badge-lg{padding:6px 16px;font-size:14px}

/* Order detail */
.order-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.order-info-card h3{margin:0 0 10px;font-size:16px;color:var(--brand)}
.order-meta div{padding:3px 0;font-size:14px}

/* Timeline */
.order-timeline{position:relative;padding-left:24px}
.order-timeline::before{content:'';position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:rgba(43,43,43,.1)}
.timeline-item{position:relative;padding-bottom:18px}
.timeline-dot{position:absolute;left:-20px;top:6px;width:10px;height:10px;border-radius:50%;border:2px solid var(--paper)}
.timeline-content{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.timeline-content time{font-size:13px;color:rgba(43,43,43,.5)}
.timeline-content p{width:100%;margin:4px 0 0;font-size:13px;color:rgba(43,43,43,.6)}

/* Address grid */
.address-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.address-card{display:flex;flex-direction:column}
.address-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.address-badges{display:flex;gap:6px;flex-wrap:wrap}
.mini-badge{font-size:11px;padding:2px 8px;background:var(--brand-10);border-radius:999px;border:1px solid var(--brand-18);white-space:nowrap}
.address-body{font-size:14px;color:rgba(43,43,43,.8);flex:1;margin-bottom:14px;line-height:1.6}
.address-actions{display:flex;gap:8px;border-top:1px solid rgba(43,43,43,.06);padding-top:12px}
.address-actions .btn{padding:8px 16px;font-size:13px;line-height:1.4;box-sizing:border-box}

/* Account link in header */
.account-link{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--paper);border:1px solid var(--brand-18);color:var(--brand);text-decoration:none;transition:all .15s}
.account-link:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(43,43,43,.10)}
.account-link.logged-in{background:var(--brand);color:#fff;border-color:var(--brand)}

/* --- RESPONSIVE --- */
@media (max-width:860px){
  .hero{grid-template-columns:1fr}
  .logo{width:190px;max-width:56vw}
  .product-detail-grid{grid-template-columns:1fr}
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .account-layout{grid-template-columns:1fr}
  .account-sidebar{position:static}
  .account-nav{flex-direction:row;flex-wrap:wrap;gap:4px}
  .account-nav a{flex:1;min-width:auto;justify-content:center;font-size:13px;padding:8px 10px}
  .account-nav a svg{display:none}
  .account-user-card{display:none}
  .dashboard-cards{grid-template-columns:repeat(3,1fr)}
  .order-detail-grid{grid-template-columns:1fr}
  .nav-wrap{justify-content:space-between;flex-wrap:nowrap;padding:10px 12px;position:relative}
  .nav-toggle{display:flex}
  .nav-inner{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--brand);display:none;flex-direction:column;align-items:stretch;gap:4px;padding:8px 12px 14px;border-radius:0 0 var(--radius) var(--radius);box-shadow:0 12px 32px rgba(43,43,43,.25);animation:navDropIn .2s ease}
  .nav-inner.is-open{display:flex}
  .nav-inner a{width:100%;text-align:left;border-radius:var(--radius-sm);padding:12px 16px;font-size:15px}
  @keyframes navDropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
  /* Mobile: hide header account/cart, show navbar ones */
  .header-only{display:none !important}
  .nav-actions{display:flex}
  .cart-hover-dropdown{display:none !important}
  .newsletter-inner{flex-direction:column;text-align:center;gap:10px;padding:14px 0}
  .newsletter-text{white-space:normal;flex-direction:column;gap:2px}
  .newsletter-form{max-width:100%}
  .newsletter-input-wrap{flex-direction:column}
}
@media (max-width:600px){
  .header-inner{padding:12px}
  .card{padding:16px}
  .product-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .form-row:has(> :nth-child(3)){grid-template-columns:1fr}
  .cart-item{grid-template-columns:60px 1fr;gap:10px}
  .cart-item-actions,.cart-item-total{grid-column:2}
  .footer-inner{grid-template-columns:1fr}
  .checkout-steps .step{padding:8px 6px;font-size:12px}
  .type-selector{flex-direction:column}
}

/* Customer type selector PF/PJ */
.type-selector{display:flex;gap:10px}
.type-option{display:flex;align-items:center;gap:6px;padding:10px 16px;border:2px solid rgba(0,0,0,.1);border-radius:12px;cursor:pointer;transition:all .2s;flex:1}
.type-option:hover{border-color:var(--brand)}
.type-option:has(input:checked){border-color:var(--brand);background:rgba(107,78,46,.06)}
.type-option input[type="radio"]{display:none}
.type-option span{font-weight:600;font-size:14px}
.customer-type-fields{transition:all .2s}

/* Newsletter Bar (homepage only, above footer) */
.newsletter-bar{background:var(--brand);padding:0 30px;max-width:1100px;margin:32px auto 0;border-radius:var(--radius) var(--radius) 0 0}
.newsletter-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 0}
.newsletter-text{color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;gap:10px;white-space:nowrap}
.newsletter-subtitle{font-weight:400;font-size:13px;color:rgba(255,255,255,.7)}
.newsletter-form{flex:1;max-width:540px}
.newsletter-input-wrap{display:flex;gap:8px}
.newsletter-input{flex:1;padding:10px 14px;border:none;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:#2b2b2b;outline:none}
.newsletter-input::placeholder{color:rgba(43,43,43,.4)}
.newsletter-btn{white-space:nowrap;padding:10px 30px;background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.3);font-weight:700;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;font-size:14px}
.newsletter-btn:hover{background:rgba(255,255,255,.28)}
.nl-msg{padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;display:inline-block}
.nl-msg-success{background:rgba(255,255,255,.15);color:#a7f3d0}
.nl-msg-info{background:rgba(255,255,255,.15);color:#bfdbfe}
.nl-msg-error{background:rgba(255,255,255,.15);color:#fecaca}

/* Floating cart (sticky on right side, outside main) */
.floating-cart{position:fixed;top:70px;left:calc(50% + 550px + 25px);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;transform:translateY(-10px);display:none}
@media (min-width:1250px){.floating-cart{display:block}}
.floating-cart.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.floating-cart-btn{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--brand);color:#fff;text-decoration:none;box-shadow:0 4px 16px rgba(43,43,43,.2);position:relative;transition:all .15s}
.floating-cart-btn:hover{transform:scale(1.05);box-shadow:0 6px 24px rgba(43,43,43,.25)}
.floating-cart-badge{position:absolute;top:-2px;right:-2px;background:#fff;color:var(--brand);font-size:11px;font-weight:800;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.floating-cart-dropdown{display:none;position:absolute;top:0;right:calc(100% + 10px);width:300px;background:var(--paper);border:1px solid rgba(43,43,43,.1);border-radius:var(--radius);box-shadow:0 16px 40px rgba(43,43,43,.18);padding:14px}
.floating-cart:hover .floating-cart-dropdown{display:block}
.fc-item{display:flex;align-items:center;gap:6px;padding:6px 0;font-size:13px;border-bottom:1px solid rgba(43,43,43,.06)}
.fc-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}
.fc-name small{color:rgba(43,43,43,.5)}
.fc-qty{color:rgba(43,43,43,.5);font-size:12px;white-space:nowrap}
.fc-price{font-weight:700;white-space:nowrap;color:var(--ink)}
.fc-total{display:flex;justify-content:space-between;padding:10px 0 4px;margin-top:4px;border-top:2px solid rgba(43,43,43,.1);font-size:15px;color:var(--brand)}

/* Custom Modal */
.custom-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s;backdrop-filter:blur(4px)}
.custom-modal-overlay.visible{opacity:1}
.custom-modal{background:#fff;border-radius:16px;box-shadow:0 25px 60px rgba(0,0,0,.2);max-width:420px;width:100%;padding:28px;transform:scale(.95) translateY(10px);transition:transform .2s}
.custom-modal-overlay.visible .custom-modal{transform:scale(1) translateY(0)}
.custom-modal-icon{font-size:36px;text-align:center;margin-bottom:12px}
.custom-modal-title{font-size:18px;font-weight:800;text-align:center;margin:0 0 8px}
.custom-modal-message{font-size:14px;color:rgba(43,43,43,.7);text-align:center;line-height:1.6;margin:0 0 24px}
.custom-modal-actions{display:flex;gap:10px;justify-content:center}
.custom-modal-actions .btn{min-width:120px;padding:10px 24px;border-radius:999px}

/* Custom form validation tooltip */
.field-error{position:relative}
.field-error input,.field-error textarea,.field-error select{border-color:var(--danger) !important}
.field-error-msg{display:block;font-size:12px;color:var(--danger);font-weight:600;margin-top:4px;animation:shakeIn .3s ease}
@keyframes shakeIn{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}50%{transform:translateX(4px)}75%{transform:translateX(-2px)}}

/* FAN Courier Address Dropdowns */
.fan-select-wrapper{position:relative;width:100%}
.fan-select-search{width:100%;padding:10px 14px;border:2px solid rgba(43,43,43,.12);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;background:var(--paper);transition:border-color .15s;cursor:text}
.fan-select-search:focus{outline:none;border-color:var(--brand)}
.fan-select-search::placeholder{color:rgba(43,43,43,.4)}
.fan-select-dropdown{position:absolute;top:100%;left:0;right:0;max-height:220px;overflow-y:auto;background:var(--paper);border:2px solid var(--brand-30);border-radius:var(--radius-sm);box-shadow:0 12px 32px rgba(43,43,43,.15);z-index:200;margin-top:4px}
.fan-select-option{padding:10px 14px;font-size:14px;cursor:pointer;transition:background .1s}
.fan-select-option:hover{background:var(--brand-10);color:var(--brand)}
.fan-select-empty{padding:14px;font-size:13px;color:rgba(43,43,43,.5);text-align:center;font-style:italic}
.fan-autocomplete-wrapper{position:relative;width:100%}
.fan-autocomplete-dropdown{position:absolute;top:100%;left:0;right:0}
.fan-select-option-active{background:var(--brand-10,rgba(107,78,46,.1));font-weight:600}
.fan-postcode-hint{margin-top:6px}
.fan-postcode-suggestion{display:inline-block;padding:4px 12px;background:var(--brand-10,rgba(107,78,46,.1));border:1px dashed var(--brand-30,rgba(107,78,46,.3));border-radius:6px;font-size:13px;color:var(--brand,#6b4e2e);cursor:pointer;transition:background .15s}
.fan-postcode-suggestion:hover{background:var(--brand-20,rgba(107,78,46,.2))}
.field-error .fan-select-search{border-color:var(--danger) !important}
