/* ============================================================
   PURPLE MAHIKA — Enchanted Café Theme  (v2: cuter + animated)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:ital,wght@0,400;0,600;0,700;1,400&display=swap');

:root {
  --plum:#3a1d5c; --purple-deep:#4a2c5a; --purple:#6b3fa0; --purple-soft:#b18fd6;
  --lavender:#d9c2f0; --blush:#f3d9f0; --gold:#d4af37; --gold-soft:#f0e3b8;
  --cream:#fbf6ef; --cream-deep:#f3e9da; --ink:#3a2740; --shadow:rgba(74,44,90,0.18);
  --grad-purple:linear-gradient(160deg,#7d52b8 0%,#5a3496 45%,#3a1d5c 100%);
  --grad-soft:linear-gradient(160deg,#f7ecff 0%,#f3d9f0 100%);
}
* { box-sizing:border-box; margin:0; padding:0; }
body { font-family:'Nunito',system-ui,sans-serif; background:var(--cream); color:var(--ink); line-height:1.65; overflow-x:hidden; }
h1,h2,h3,.display { font-family:'Fredoka',sans-serif; }

/* AMBIENT MOTION LAYER */
.magic-layer { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.magic-layer .floatie { position:absolute; opacity:0.6; animation:drift linear infinite; font-size:1.8rem; filter:drop-shadow(0 2px 4px rgba(74,44,90,0.12)); }
@keyframes drift { 0%{transform:translateY(0) translateX(0) rotate(0);} 50%{transform:translateY(-40vh) translateX(30px) rotate(12deg);} 100%{transform:translateY(-95vh) translateX(-20px) rotate(-8deg); opacity:0;} }
.magic-layer .twinkle { position:absolute; color:var(--gold); animation:twinkle ease-in-out infinite; opacity:0; }
@keyframes twinkle { 0%,100%{opacity:0; transform:scale(0.6);} 50%{opacity:0.9; transform:scale(1.1);} }
.boba-field { position:fixed; left:0; right:0; bottom:0; height:120px; pointer-events:none; z-index:0; }
.boba-field .pearl { position:absolute; bottom:-20px; width:16px; height:16px; border-radius:50%; background:radial-gradient(circle at 30% 30%,#6b4a2e,#2e1a0f); animation:rise linear infinite; opacity:0.85; }
@keyframes rise { 0%{transform:translateY(0) translateX(0); opacity:0;} 10%{opacity:0.85;} 100%{transform:translateY(-160px) translateX(20px); opacity:0;} }
.awning,nav.main,.wrap,footer.site,.hero { position:relative; z-index:1; }
@media (prefers-reduced-motion:reduce) { .floatie,.twinkle,.pearl { animation:none !important; opacity:0.3; } }

/* AWNING */
.awning { background:var(--grad-purple); padding:26px 20px 20px; text-align:center; box-shadow:0 4px 18px var(--shadow); }
.awning::after { content:""; position:absolute; left:0; right:0; bottom:-22px; height:24px; background-image:radial-gradient(circle at 50% 0,#4a2c80 0,#4a2c80 60%,transparent 62%); background-size:48px 24px; background-repeat:repeat-x; z-index:2; }
.awning h1 { font-size:2.4rem; font-weight:700; color:var(--cream); letter-spacing:0.5px; text-shadow:0 2px 8px rgba(0,0,0,0.25); }
.awning h1 .sparkle-emoji { display:inline-block; animation:spin 6s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.awning .tagline { color:var(--gold-soft); font-style:italic; font-size:1rem; margin-top:2px; }
.awning .stripe-accent { width:90px; height:3px; background:var(--gold); margin:10px auto 0; border-radius:2px; }

/* NAV */
nav.main { background:var(--plum); display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:6px; padding:12px 10px; margin-top:22px; }
nav.main a { font-family:'Fredoka',sans-serif; color:var(--cream); text-decoration:none; font-size:0.98rem; padding:7px 16px; border-radius:20px; transition:background 0.2s,transform 0.15s; }
nav.main a:hover, nav.main a.active { background:var(--purple-soft); color:var(--plum); transform:translateY(-1px); }
.cart-link { position:relative; }
.cart-badge { position:absolute; top:-4px; right:-2px; background:var(--gold); color:var(--plum); font-family:'Fredoka',sans-serif; font-weight:700; font-size:0.72rem; min-width:19px; height:19px; border-radius:10px; padding:0 5px; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 5px rgba(0,0,0,0.25); animation:pop 0.3s ease; }
@keyframes pop { 0%{transform:scale(0);} 70%{transform:scale(1.25);} 100%{transform:scale(1);} }

/* LAYOUT */
.wrap { max-width:1040px; margin:0 auto; padding:28px 18px 90px; }
.card { background:#fff; border:1px solid var(--cream-deep); border-radius:20px; padding:24px; box-shadow:0 4px 14px var(--shadow); }

/* HOMEPAGE */
.hero { background:var(--grad-purple); border-radius:28px; padding:56px 28px 60px; text-align:center; color:var(--cream); overflow:hidden; margin-bottom:40px; box-shadow:0 10px 30px var(--shadow); }
.hero h2 { font-size:clamp(2.2rem,6vw,3.6rem); font-weight:700; line-height:1.05; color:#fff; text-shadow:0 3px 12px rgba(0,0,0,0.25); margin-bottom:14px; }
.hero p.lede { font-size:1.15rem; color:var(--lavender); max-width:560px; margin:0 auto 26px; }
.hero .cup-spin { font-size:3.4rem; display:inline-block; animation:bobble 3s ease-in-out infinite; }
@keyframes bobble { 0%,100%{transform:translateY(0) rotate(-4deg);} 50%{transform:translateY(-12px) rotate(4deg);} }
.section-block { margin:48px 0; }
.section-block h2.section { text-align:center; }
.eyebrow { text-align:center; font-family:'Fredoka',sans-serif; color:var(--gold); letter-spacing:2px; text-transform:uppercase; font-size:0.8rem; margin-bottom:6px; }
.magic-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.magic-card { background:var(--grad-soft); border-radius:20px; padding:26px 20px; text-align:center; border:1px solid var(--lavender); transition:transform 0.2s; }
.magic-card:hover { transform:translateY(-5px) rotate(-1deg); }
.magic-card .ic { font-size:2.6rem; display:block; margin-bottom:10px; animation:bobble 4s ease-in-out infinite; }
.magic-card h3 { color:var(--purple); font-size:1.25rem; margin-bottom:6px; }
.magic-card p { font-size:0.94rem; color:var(--ink); }
.story { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:center; }
@media (max-width:720px){ .story { grid-template-columns:1fr; } }
.story .story-art { background:var(--grad-purple); border-radius:24px; min-height:240px; display:flex; align-items:center; justify-content:center; font-size:5rem; box-shadow:0 8px 22px var(--shadow); }
.story h2 { color:var(--purple); margin-bottom:12px; }
.cta-banner { background:var(--grad-purple); border-radius:24px; padding:40px 28px; text-align:center; color:var(--cream); box-shadow:0 8px 24px var(--shadow); margin:48px 0; }
.cta-banner h2 { color:#fff; font-size:1.9rem; margin-bottom:8px; }
.cta-banner p { color:var(--lavender); margin-bottom:20px; }

/* MENU */
.menu-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:22px; }
.product { background:#fff; border-radius:20px; overflow:hidden; box-shadow:0 4px 14px var(--shadow); border:1px solid var(--cream-deep); transition:transform 0.18s,box-shadow 0.18s; display:flex; flex-direction:column; }
.product:hover { transform:translateY(-5px) rotate(-0.5deg); box-shadow:0 12px 26px var(--shadow); }
.product .pimg { height:150px; background:var(--grad-soft); background-size:cover; background-position:center; }
.product .pbody { padding:16px; flex:1; display:flex; flex-direction:column; }
.product h3 { color:var(--purple); font-size:1.2rem; }
.product .desc { font-size:0.88rem; color:#6b5a72; flex:1; margin:6px 0 10px; }
.product .price { color:var(--gold); font-weight:700; font-size:1.15rem; font-family:'Fredoka',sans-serif; }
.cat-header { display:flex; align-items:center; gap:12px; margin:38px 0 18px; }
.cat-header h2 { color:var(--purple); font-size:1.7rem; white-space:nowrap; }
.cat-header .rule { flex:1; height:2px; background:linear-gradient(90deg,var(--purple-soft),transparent); border-radius:2px; }
.cat-header .cat-ic { font-size:1.6rem; }

/* BUTTONS */
.btn { display:inline-block; font-family:'Fredoka',sans-serif; background:var(--purple); color:var(--cream); border:none; padding:12px 26px; border-radius:26px; font-size:1rem; cursor:pointer; text-decoration:none; transition:background 0.2s,transform 0.1s,box-shadow 0.2s; box-shadow:0 4px 12px rgba(107,63,160,0.3); }
.btn:hover { background:var(--purple-deep); transform:translateY(-2px); box-shadow:0 6px 16px rgba(107,63,160,0.4); }
.btn:active { transform:scale(0.97); }
.btn.gold { background:var(--gold); color:var(--plum); box-shadow:0 4px 12px rgba(212,175,55,0.4); }
.btn.gold:hover { background:#c39e2e; }
.btn.ghost { background:transparent; color:var(--purple); border:2px solid var(--purple); box-shadow:none; }
.btn.ghost:hover { background:var(--purple); color:var(--cream); }
.btn.small { padding:7px 16px; font-size:0.85rem; }
.btn.block { display:block; width:100%; text-align:center; }
.btn.big { font-size:1.15rem; padding:15px 36px; }

/* FORMS */
label { display:block; font-family:'Fredoka',sans-serif; font-size:0.92rem; color:var(--purple-deep); margin:12px 0 4px; }
input,select,textarea { width:100%; padding:11px 13px; border:1px solid var(--lavender); border-radius:12px; font-family:inherit; font-size:1rem; background:#fdfaff; }
input:focus,select:focus,textarea:focus { outline:2px solid var(--purple-soft); border-color:var(--purple-soft); }

/* CHIPS + PILLS */
.chip-row { display:flex; gap:8px; flex-wrap:wrap; margin:8px 0; }
.chip { font-family:'Fredoka',sans-serif; border:2px solid var(--purple-soft); background:#fff; color:var(--purple); border-radius:22px; padding:8px 18px; cursor:pointer; font-size:0.95rem; transition:all 0.15s; }
.chip:hover { background:var(--blush); }
.chip.selected { background:var(--purple); color:var(--cream); border-color:var(--purple); }
.points-pill { display:inline-block; font-family:'Fredoka',sans-serif; background:var(--gold-soft); color:var(--purple-deep); border-radius:22px; padding:5px 16px; font-size:0.92rem; font-weight:700; }

/* TABLES */
table.data { width:100%; border-collapse:collapse; background:#fff; border-radius:14px; overflow:hidden; box-shadow:0 3px 10px var(--shadow); }
table.data th { background:var(--purple); color:var(--cream); text-align:left; padding:11px 13px; font-family:'Fredoka',sans-serif; font-size:0.9rem; }
table.data td { padding:11px 13px; border-bottom:1px solid var(--cream-deep); font-size:0.92rem; }
table.data tr:hover td { background:var(--blush); }

/* FLASH */
.flash { padding:13px 17px; border-radius:12px; margin-bottom:16px; font-weight:600; }
.flash.ok { background:#e6f5e9; color:#1f6b35; border:1px solid #b6e0c0; }
.flash.err { background:#fbe6ea; color:#8b1e35; border:1px solid #f0bcc8; }

/* FOOTER */
footer.site { background:var(--plum); color:var(--gold-soft); text-align:center; padding:28px; font-size:0.9rem; font-style:italic; }

/* MISC */
h2.section { color:var(--purple); margin-bottom:16px; font-size:1.7rem; }
.muted { color:#8a7b92; font-size:0.88rem; }
.center { text-align:center; }
.sparkle::before { content:"✨ "; }

/* PASSWORD SHOW/HIDE TOGGLE */
.pw-wrap { position:relative; }
.pw-wrap input { padding-right:64px; }
.pw-toggle { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:var(--lavender); color:var(--plum); border:none; border-radius:14px; padding:5px 12px; font-family:'Fredoka',sans-serif; font-size:0.8rem; cursor:pointer; }
.pw-toggle:hover { background:var(--purple-soft); }

/* ADMIN SIDE-BY-SIDE LAYOUT — add-form on the left, list on the right */
.admin-split { display:grid; grid-template-columns:340px 1fr; gap:22px; align-items:start; }
.admin-split .form-side { position:sticky; top:16px; }
@media (max-width:880px){ .admin-split { grid-template-columns:1fr; } .admin-split .form-side { position:static; } }
