:root{
  --ink:#14201a;
  --emerald:#0a6e4e;
  --emerald-deep:#06402f;
  --gold:#caa24a;
  --paper:#ffffff;
  --cream:#f7f6f1;
  --mist:#eef2ee;
  --line:rgba(20,32,26,.12);
  --danger:#c0392b;
  --radius:14px;
  --shadow:0 18px 40px -24px rgba(6,64,47,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:var(--cream);color:var(--ink);line-height:1.55}
h1,h2,h3,.disp{font-family:'Unbounded',system-ui,sans-serif;font-weight:500;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.muted{color:#5d6b62}
.row{display:flex;gap:12px;align-items:center}
.spread{display:flex;justify-content:space-between;align-items:center;gap:12px}
.grow{flex:1}
.right{text-align:right}
.hide{display:none!important}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:inherit;
  font-weight:700;font-size:.9rem;padding:11px 18px;border-radius:40px;background:var(--emerald);color:#fff;transition:.15s}
.btn:hover{background:var(--emerald-deep);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--emerald-deep);border:1.5px solid var(--line)}
.btn.ghost:hover{background:var(--mist);transform:none}
.btn.sm{padding:7px 13px;font-size:.8rem}
.btn.block{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn.danger{background:var(--danger)}

/* header */
header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:20px;padding:14px 0}
.brand{font-family:'Unbounded';font-weight:600;color:var(--emerald-deep);font-size:1.15rem;margin-right:auto}
.brand small{display:block;font-family:'Plus Jakarta Sans';font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:700}
.nav a.link{font-weight:600;font-size:.86rem;color:var(--ink)}
.nav a.link:hover{color:var(--emerald)}
.cartbtn{position:relative}
.badge{position:absolute;top:-6px;right:-8px;background:var(--gold);color:#1c1303;font-size:.62rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 4px}
.announce{background:var(--emerald-deep);color:#eafff4;text-align:center;font-size:.78rem;font-weight:600;padding:8px}

/* hero */
.hero{padding:64px 0 40px}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);max-width:14ch}
.hero p{margin:16px 0 24px;font-size:1.05rem;max-width:46ch;color:#46554c}
.pill{display:inline-block;background:var(--mist);color:var(--emerald-deep);font-weight:700;font-size:.72rem;
  letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:30px;margin-bottom:18px}

/* menu */
.cat{margin:40px 0}
.cat h2{font-size:1.5rem;margin-bottom:4px}
.cat .bar{height:3px;width:46px;background:var(--gold);border-radius:2px;margin:8px 0 20px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.card .ph{aspect-ratio:16/10;background:var(--mist) center/cover;display:grid;place-items:center;color:#9aa89f;font-size:.8rem}
.card .body{padding:14px 15px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card h3{font-size:1.02rem}
.card .desc{font-size:.84rem;color:#5d6b62;flex:1}
.card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.price{font-weight:800;color:var(--emerald-deep)}
.soldout{filter:grayscale(.7);opacity:.7}
.tag-sold{font-size:.7rem;font-weight:800;color:var(--danger);text-transform:uppercase;letter-spacing:.06em}
.chip{display:inline-block;background:var(--mist);font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:20px;color:#3f4d44}

/* drawer + modal */
.scrim{position:fixed;inset:0;background:rgba(10,20,15,.45);z-index:60}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,100%);background:var(--paper);z-index:61;
  display:flex;flex-direction:column;box-shadow:var(--shadow)}
.drawer header{position:static;background:none;border-bottom:1px solid var(--line);padding:0}
.drawer .dh{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.drawer .dbody{flex:1;overflow:auto;padding:16px 18px}
.drawer .dfoot{border-top:1px solid var(--line);padding:16px 18px}
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:61;padding:18px}
.modal .box{background:var(--paper);border-radius:var(--radius);max-width:440px;width:100%;padding:22px;box-shadow:var(--shadow)}

/* cart lines + forms */
.line{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.qty{display:flex;align-items:center;gap:8px}
.qty button{width:26px;height:26px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:700}
label{display:block;font-size:.78rem;font-weight:700;margin:12px 0 5px;color:#3f4d44}
input,textarea,select{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem;background:#fff}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--emerald)}
.note{font-size:.78rem;color:#5d6b62}
.cs-coming{background:var(--mist);border-radius:10px;padding:10px 12px;font-size:.8rem;color:#3f4d44;margin-top:10px}

/* toast */
.toasts{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:90;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:#fff;padding:10px 16px;border-radius:30px;font-size:.85rem;font-weight:600;box-shadow:var(--shadow)}
.toast.success{background:var(--emerald)}
.toast.error{background:var(--danger)}

/* admin */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin:18px 0 22px;flex-wrap:wrap}
.tabs button{background:none;border:none;padding:10px 14px;font-family:inherit;font-weight:700;font-size:.9rem;
  color:#5d6b62;cursor:pointer;border-bottom:3px solid transparent}
.tabs button.active{color:var(--emerald-deep);border-bottom-color:var(--emerald)}
table{width:100%;border-collapse:collapse;font-size:.86rem}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);vertical-align:top}
th{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#5d6b62}
.status{font-size:.72rem;font-weight:800;padding:3px 9px;border-radius:20px;text-transform:capitalize}
.s-pending{background:#fdf0d5;color:#8a5a00}
.s-confirmed{background:#e1ecff;color:#234b9e}
.s-ready{background:#e6f6ec;color:#1f7a44}
.s-completed{background:#e9efe6;color:#3f4d44}
.s-cancelled,.s-no_show{background:#fbe3df;color:#9e2c1c}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px}
.foot-site{margin-top:60px;padding:30px 0;border-top:1px solid var(--line);color:#5d6b62;font-size:.84rem}
@media(max-width:600px){.hero{padding:40px 0 26px}.nav a.link{display:none}}

/* contact + map ("Find us") */
.findus{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}
.findus .info{display:flex;flex-direction:column;gap:6px}
.findus address{font-style:normal;color:#3f4d44;line-height:1.7}
.contact-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.contact-list a{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:var(--ink)}
.contact-list a:hover{color:var(--emerald)}
.contact-list .ic{width:30px;height:30px;border-radius:9px;background:var(--mist);display:grid;place-items:center;font-size:.95rem}
#map,#admin-map{width:100%;border-radius:var(--radius);border:1px solid var(--line);z-index:1}
#map{min-height:300px;height:100%}
#admin-map{height:260px;margin-top:8px}
.fieldset{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.fieldset .full{grid-column:1/-1}
@media(max-width:680px){.findus{grid-template-columns:1fr}.fieldset{grid-template-columns:1fr}#map{min-height:240px}}
