/* =========================
   F-City Cafe – Café Theme
   ========================= */

:root{
  --bg:#0f0f0f;
  --paper:#141414;
  --ink:#f5f5f5;
  --muted:#bdbdbd;
  --stroke:#262626;
  --accent:#f4c27f;
  --accent-2:#c77752;
  --shadow:0 12px 30px rgba(0,0,0,.35);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--ink);
  background:
    radial-gradient(80rem 40rem at 10% -20%, #1d1d1d 0%, transparent 60%),
    radial-gradient(80rem 40rem at 110% 0%, #1a120d 0%, transparent 55%),
    var(--bg);
  font-family:"Inter", system-ui, Segoe UI, Roboto, Arial;
}

/* Header */
header{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(10px);
  background:linear-gradient(180deg,rgba(20,20,20,.85),rgba(20,20,20,.65));
  border-bottom:1px solid var(--stroke);
  padding:10px 16px 8px;
  display:flex; align-items:center; gap:12px;
}
.brand{display:flex; align-items:center; gap:10px}
.logo{width:34px; height:34px; object-fit:contain; border-radius:8px; box-shadow:0 2px 6px rgba(0,0,0,.25)}
header h1{margin:0; font-size:18px; letter-spacing:.4px}
.badge{
  border:1px solid var(--stroke); background:#1a1a1a; color:var(--muted);
  padding:6px 10px; border-radius:999px; font-size:12px
}
.social{margin-left:auto; display:flex; align-items:center; gap:8px}
.pill{
  display:flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px;
  font-size:12px; border:1px solid #2a2a2a; background:#141414; color:var(--ink);
  text-decoration:none; transition:.2s background,.2s transform
}
.pill:hover{background:#1b1b1b; transform:translateY(-1px)}
.pill svg{width:16px; height:16px; fill:currentColor}
.pill.zalo{background:#0a68fe1a; border-color:#0a68fe33; color:#cfe0ff}
.pill.fb{background:#1877f21a; border-color:#1877f233; color:#d4e3ff}

/* Hero */
.hero{
  max-width:1100px; margin:18px auto 0; padding:0 16px 10px;
  display:grid; grid-template-columns:1.2fr .8fr; gap:18px; align-items:center;
}
.hero .copy h2{margin:8px 0 6px; font-size:28px; font-weight:800}
.hero .copy p{margin:0; color:#cfcfcf}
.hero .image{
  height:180px; border-radius:20px; overflow:hidden; border:1px solid var(--stroke);
  background:url('https://images.unsplash.com/photo-1504754524776-8f4f37790ca0?q=80&w=1600&auto=format&fit=crop') center/cover no-repeat;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}

/* Layout */
.wrap{max-width:1100px; margin:6px auto 24px; padding:0 16px}

/* Category + Grid */
.category{margin:22px 0}
.cat-title{margin:0 0 8px; font-size:18px; letter-spacing:.6px; color:#ffe7c2}
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:16px}

/* Product Card */
.card{
  border:1px solid var(--stroke);
  background:linear-gradient(180deg,#191716,#141414 65%);
  border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 1px 0 rgba(255,255,255,.03) inset;
  transition:.25s transform,.25s box-shadow,.25s border-color
}
.card:hover{transform:translateY(-4px); border-color:#2e2e2e; box-shadow:var(--shadow)}
.card img{height:160px; width:100%; object-fit:cover; filter:saturate(1.05)}
.card .c{padding:12px; position:relative}
.card .c:after{content:""; position:absolute; inset:auto 12px 0 12px; height:1px;
  background:linear-gradient(90deg,transparent,#2b2b2b,transparent)}
.name{font-weight:700; letter-spacing:.2px}
.en{font-size:12px; color:var(--muted); margin:2px 0 8px}
.price{font-weight:800; color:var(--accent); margin-bottom:10px}

/* Buttons */
.btn{
  border:1px solid var(--stroke); background:#1a1a1a; color:var(--ink);
  border-radius:12px; padding:8px 12px; cursor:pointer;
  transition:.2s background,.2s transform
}
.btn:hover{background:#202020; transform:translateY(-1px)}
.btn.primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  border-color:transparent; color:#1a120d; font-weight:700
}
.btn.primary:hover{filter:brightness(1.05)}

/* Inputs */
input{
  background:#0f0f0f; color:var(--ink); border:1px solid var(--stroke);
  padding:10px 12px; border-radius:12px; width:100%
}
input::placeholder{ color:#a7abb3; }
.consent{font-size:12px; color:var(--muted)}

/* Contact Dock */
.contact-dock{
  position:fixed; right:16px; bottom:16px;
  display:flex; flex-direction:column; gap:10px; z-index:25
}
.fab{
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:#111; border:1px solid #2a2a2a; box-shadow:0 10px 24px rgba(0,0,0,.35);
  text-decoration:none; color:#fff; transition:.2s transform,.2s filter
}
.fab svg{width:22px; height:22px}
.fab.zalo{background:#0a68fe; border-color:transparent; font-weight:800}
.fab.fb{background:#1877f2; border-color:transparent}
.fab:hover{transform:translateY(-2px); filter:brightness(1.05)}

/* Footer */
footer{color:var(--muted); text-align:center; padding:24px 0 40px; border-top:1px solid var(--stroke); margin-top:24px}
footer a{color:var(--accent); text-decoration:none}
footer a:hover{text-decoration:underline}

/* Language pills */
.lang{display:flex; gap:6px; margin-right:8px}
.lang .pill{opacity:.8}
.lang .pill.active{opacity:1; box-shadow:0 0 0 1px #fff inset}

/* Accordion */
.cat { margin: 28px 0; border-radius: 14px; background: rgba(255,255,255,0.04); }
.cat > summary {
  list-style: none; cursor: pointer; padding: 16px 18px; font-weight: 700;
  display: flex; align-items: center; gap: 10px; position: sticky; top: 64px; z-index: 2;
  background: linear-gradient(180deg, rgba(12,12,12,.9), rgba(12,12,12,.6));
  border-radius: 14px; backdrop-filter: blur(6px);
}
.cat > summary::marker { content: ""; }
.cat[open] > summary .chev { transform: rotate(90deg); }
.cat .grid { padding: 18px; display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: 16px; }
.tag { padding: 2px 8px; border-radius: 999px; font-size: 12px; background: rgba(255,255,255,.08); }
.subhead { padding: 0 18px 6px; font-weight: 600; color: #d7d7d7; display: flex; align-items: center; gap: 8px; }

.card .sizes { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.sizechip {
  border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06);
  padding: 6px 10px; border-radius: 10px; font-size: 12px; cursor: pointer;
}
.sizechip:hover { background: rgba(255,255,255,.12); }
.card .c .price { margin-top: 6px; }

/* ------------------------------
   FAB + Drawer (two-section cart)
   ------------------------------ */
.fab{
  position:fixed; right:20px; bottom:24px;
  display:flex; align-items:center; gap:.5rem;
  padding:.9rem 1.1rem; border-radius:999px;
  background:linear-gradient(180deg,#ffcf8a,#e6a351);
  color:#111; font-weight:700; box-shadow:0 8px 24px rgba(0,0,0,.35);
  z-index:60; border:none; cursor:pointer;
}
.fab:active{ transform:translateY(1px); }

.backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:55; opacity:0; pointer-events:none; transition:.2s ease;
}
.backdrop.show{ opacity:1; pointer-events:auto; }

.cart{
  position:fixed; right:0; top:0; height:100vh; width:min(420px,100%);
  background:rgba(20,20,20,.92); backdrop-filter: blur(8px);
  border-left:1px solid rgba(255,255,255,.08);
  z-index:60; display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .25s ease;
}
.cart.show{ transform:translateX(0); }
.cart.hidden{ display:block; }

.cart-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 16px; border-bottom:1px solid rgba(255,255,255,.08);
}
.cart-head .title{ display:flex; align-items:center; gap:.6rem; font-size:1.1rem; }
.icon-btn{
  background:transparent; border:none; color:#ddd; font-size:1rem;
  padding:.25rem .5rem; cursor:pointer; border-radius:.4rem;
}
.icon-btn:hover{ background:rgba(255,255,255,.06); }

/* New sections */
.cart-sections { display:flex; flex-direction:column; height:100%; }
.section-title {
  font-weight:800; letter-spacing:.2px; margin:10px 16px 6px;
  display:flex; align-items:center; gap:.5rem;
}
.order-section { display:flex; flex-direction:column; min-height:0; }
.customer-section { border-top:1px solid rgba(255,255,255,.08); margin-top:8px; padding-top:8px; }

/* Order list */
.order-list {
  flex:1; min-height:0; overflow:auto; padding:0 16px 8px;
}
.order-list.empty { display:flex; align-items:center; justify-content:center; }
.empty-note { padding:24px 0; }

.order-row {
  display:grid; grid-template-columns: 1fr auto; gap:8px 12px;
  padding:12px 0; border-bottom:1px dashed rgba(255,255,255,.10);
}
.order-row:last-child { border-bottom:none; }

.order-row .meta { min-width:0; }
.order-row .name{
  font-weight:800; font-size:1.06rem; line-height:1.3; color:#f2f2f3;
  white-space:normal; word-break:break-word;
}
.order-row .attrs{ display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.order-row .pill{
  padding:2px 8px; border-radius:999px; font-size:12px;
  border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:#ddd;
}

.order-row .controls{ display:flex; align-items:center; gap:10px; justify-self:end; }
.order-row .unit{ font-weight:700; font-size:.95rem; opacity:.95; text-align:right; }
.order-row .qtyctl{ display:flex; align-items:center; gap:6px; }
.order-row .qtyctl .btn{ width:28px; height:28px; padding:0; border-radius:8px; }
.order-row .line-total{ font-weight:800; text-align:right; }

/* Totals (sticky) */
.order-totals{
  position:sticky; bottom:0; background:rgba(20,20,20,.95);
  backdrop-filter:blur(6px); padding:10px 16px 12px; border-top:1px solid rgba(255,255,255,.08);
}
.order-totals .row{
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 0; font-weight:700;
}
.order-totals .row.small{ font-weight:600; }
.order-totals .row.grand{ font-size:1.08rem; }

/* Form */
.cart-form{ padding:10px 16px 16px; display:grid; gap:.6rem; }
.cart-form input[type="text"],
.cart-form input[type="email"],
.cart-form input[type="tel"]{
  width:100%; padding:.8rem .9rem; border-radius:.7rem;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06); color:#f6f6f6;
}
.cart-form input::placeholder{ color:#a7abb3; }
.cart-form .consent{ display:flex; align-items:center; gap:.6rem; font-size:.95rem; color:#cfcfcf; }
.w-full{ width:100%; }

/* Responsive */
@media (max-width:920px){
  .hero{grid-template-columns:1fr}
}
@media (min-width: 1200px){
  .fab{ bottom:28px; right:26px; }
}
@media (max-width: 480px){
  .page { padding-bottom:90px; }
}
