/* =====================================================
   Bistro Słodkie Słone — design system
   Tokeny wg README (kolory, typografia, promienie, cienie)
   ===================================================== */

:root{
  --orange:#E67E22;
  --orange-light:#F2A65A;
  --tint-1:#F4EDE3; --tint-2:#FCEBD8; --tint-3:#FDF6EE;
  --red:#C0392B;
  --olive:#6B8E23;
  --olive-tint:#EAF0DF; --olive-tint-2:#DCEBD3;
  --red-tint:#F6E3E0;
  --ink:#2D3436;
  --muted:#7a7f82;
  --faint:#9a938a; --fainter:#b0a99e;
  --bg:#FAF9F6;
  --bg-alt:#F1EFEA; --bg-gutter:#EFEDE7;
  --card:#FFFFFF;
  --border-card:#F0ECE4; --border-input:#E8E3DA; --border-div:#ECE9E2;
  --success:#4B6B1F; --success-2:#5C7719; --warning:#B4620F; --error:#C0392B;
  --shadow-card:0 10px 30px rgba(45,52,54,.05);
  --shadow-elev:0 14px 40px rgba(45,52,54,.06);
  --shadow-btn:0 12px 26px rgba(230,126,34,.3);
  --grad-logo:linear-gradient(135deg,#E67E22,#C0392B);
  --grad-banner:linear-gradient(120deg,#C0392B,#E67E22);
  --font:'Plus Jakarta Sans',system-ui,sans-serif;
  --serif:'Newsreader',serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);font-family:var(--font);color:var(--ink);-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#d8d4ca;border-radius:8px}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font-family:inherit}
img{max-width:100%}

@keyframes riseIn{from{opacity:.4;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes spin{to{transform:rotate(360deg)}}

.screen{background:var(--bg);min-height:100vh;animation:riseIn .4s ease both}
.container{max-width:1180px;margin:0 auto;padding:0 28px}
.container.w1120{max-width:1120px}
.container.w1080{max-width:1080px}
.container.w1000{max-width:1000px}
.container.w820{max-width:820px}

/* ---------- logo ---------- */
.logo{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:17px;letter-spacing:-.02em;cursor:pointer;color:var(--ink)}
.logo .mark{width:30px;height:30px;border-radius:9px;background:var(--grad-logo);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:14px;flex:0 0 auto}
.logo.lg{font-size:19px;gap:10px}
.logo.lg .mark{width:34px;height:34px;border-radius:10px;font-size:16px}

/* ---------- przyciski ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-weight:700;font-size:13.5px;padding:9px 16px;border-radius:11px;transition:all .15s;white-space:nowrap;text-align:center}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 8px 20px rgba(230,126,34,.28)}
.btn-primary:hover{background:#d97316}
.btn-outline{background:#fff;color:var(--ink);border:1px solid #E1DDD4}
.btn-outline:hover{border-color:#cfc8bd}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#1f2426}
.btn-olive{background:var(--olive);color:#fff}
.btn-olive:hover{background:#5d7c1e}
.btn-danger{background:#fff;color:var(--red);border:1px solid var(--red)}
.btn-ghost{background:transparent;color:var(--muted)}
.btn-lg{font-size:15.5px;padding:15px 26px;border-radius:14px}
.btn-lg.btn-primary{box-shadow:var(--shadow-btn)}
.btn-block{width:100%}
.btn-cta{font-weight:800;font-size:16px;padding:16px;border-radius:14px}
.btn[disabled]{background:#EEEAE2;color:var(--fainter);cursor:default;box-shadow:none}

/* ---------- chipy / pigułki ---------- */
.chip{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12.5px;padding:6px 13px;border-radius:99px}
.chip-warm{background:var(--tint-1);border:1px solid #EBE2D4;color:var(--warning)}
.chip-olive{background:var(--olive-tint);color:var(--success-2)}
.chip-red{background:var(--red-tint);color:var(--red)}
.tag{font-weight:700;font-size:11px;padding:3px 9px;border-radius:99px}
.dot-olive{width:7px;height:7px;border-radius:99px;background:var(--olive);display:inline-block}

/* ---------- karty ---------- */
.card{background:var(--card);border-radius:20px;border:1px solid var(--border-card)}
.card.shadow{box-shadow:var(--shadow-card)}
.card.pad{padding:22px}
.card.pad-lg{padding:26px}

/* ---------- naglówki stron ---------- */
.hdr{display:flex;align-items:center;gap:14px;padding:16px 28px;border-bottom:1px solid var(--border-div)}
.hdr.sticky{position:sticky;top:0;background:rgba(250,249,246,.9);backdrop-filter:blur(12px);z-index:50}
.hdr .right{margin-left:auto;display:flex;align-items:center;gap:12px}
.eyebrow{color:var(--orange);font-weight:800;font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}
h1.page{font-size:34px;letter-spacing:-.025em;margin:0;font-weight:800;line-height:1.1}
h2.section{font-size:34px;letter-spacing:-.02em;margin:0;font-weight:800}

/* ---------- formularze ---------- */
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:7px}
.input{width:100%;border:1px solid var(--border-input);border-radius:11px;padding:12px 14px;font-size:14.5px;outline:none;background:#fff;color:var(--ink)}
.input:focus{border-color:var(--orange)}
textarea.input{min-height:80px;resize:vertical;border-radius:12px}
.icon-input{display:flex;align-items:center;gap:10px;border:1px solid var(--border-input);border-radius:12px;padding:0 14px;background:#FCFBF9}
.icon-input:focus-within{border-color:var(--orange)}
.icon-input .ic{color:#c4bdb2;font-size:15px}
.icon-input input{flex:1;border:none;background:none;outline:none;font-size:14.5px;padding:13px 0;color:var(--ink);min-width:0}
.icon-input .toggle-pass{color:var(--fainter);font-size:13px;font-weight:600;cursor:pointer;background:none;border:none;padding:0}

/* ---------- alerty / flash ---------- */
.alert{display:flex;align-items:center;gap:10px;border-radius:13px;padding:13px 16px;font-weight:700;font-size:13.5px;margin:16px auto}
.alert-success{background:var(--olive-tint);color:var(--success)}
.alert-warning{background:var(--tint-2);color:var(--warning)}
.alert-error{background:var(--red-tint);color:var(--error)}
.flash-wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* ---------- avatar ---------- */
.avatar{width:40px;height:40px;border-radius:99px;background:var(--tint-1);display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:var(--warning);flex:0 0 auto}

/* ---------- toggle (przełącznik) ---------- */
.toggle{width:46px;height:26px;border-radius:99px;position:relative;cursor:pointer;border:none;background:#E1DDD4;transition:background .15s;padding:0}
.toggle.on{background:var(--olive)}
.toggle::after{content:'';width:20px;height:20px;background:#fff;border-radius:99px;position:absolute;top:3px;left:3px;transition:left .15s}
.toggle.on::after{left:23px}

/* ============ LANDING ============ */
.nav-marketing{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;position:sticky;top:0;background:rgba(250,249,246,.82);backdrop-filter:blur(12px);z-index:50;border-bottom:1px solid var(--border-div);gap:14px;flex-wrap:wrap}
.nav-marketing .links{display:flex;align-items:center;gap:26px;font-size:14.5px;font-weight:600;color:#5b5f62}
.nav-marketing .links a:hover{color:var(--ink)}
@media(max-width:760px){.nav-marketing .links{display:none}}

.hero{display:flex;flex-wrap:wrap;gap:36px;align-items:center;padding:56px 28px 40px;max-width:1180px;margin:0 auto}
.hero .copy{flex:1 1 380px;min-width:300px}
.hero h1{font-size:60px;line-height:1.02;letter-spacing:-.03em;font-weight:800;margin:0 0 20px}
.hero h1 .serif{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--red)}
.hero .sub{font-size:18px;line-height:1.55;color:#6a6f72;max-width:460px;margin:0 0 30px}
.hero .visual{flex:1 1 380px;min-width:300px;position:relative}
.hero .rating{display:flex;align-items:center;gap:18px}
.hero .stars{color:var(--orange);font-size:17px;letter-spacing:3px}
@media(max-width:640px){.hero h1{font-size:40px}}

.img-ph{background:linear-gradient(135deg,#EFE9DE,#E5DFD2);display:flex;align-items:center;justify-content:center;color:#b3ab9b;font-weight:700;font-size:13px;overflow:hidden;position:relative}
.img-ph::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 30% 40%, rgba(230,126,34,.10), transparent 50%),radial-gradient(circle at 75% 70%, rgba(192,57,43,.08), transparent 55%)}
.img-ph span{position:relative;z-index:1}
.float-card{position:absolute;left:-14px;bottom:26px;background:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 18px 40px rgba(45,52,54,.14);display:flex;align-items:center;gap:12px}
.icon-tile{width:42px;height:42px;border-radius:12px;background:var(--tint-1);display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto}
.icon-tile.sm{width:40px;height:40px;border-radius:12px;font-size:17px}

.trust{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 38px;padding:20px;color:var(--faint);font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase}

.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.dish-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--border-card);box-shadow:var(--shadow-card);display:flex;flex-direction:column}
.dish-card .body{padding:16px;display:flex;flex-direction:column;flex:1}
.dish-card .titleline{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.dish-card .name{font-weight:800;font-size:16.5px;letter-spacing:-.01em}
.dish-card .price{font-weight:800;font-size:16.5px;color:var(--red);white-space:nowrap}
.dish-card .desc{font-size:13px;color:var(--muted);margin:6px 0 12px;line-height:1.45;flex:1}
.dish-card .meta{display:flex;gap:14px;font-size:12px;color:var(--faint);font-weight:600;margin-bottom:12px}
.dish-card .allergens{font-size:11px;color:var(--fainter);margin-bottom:12px}
.fav-btn{position:absolute;top:11px;right:11px;width:36px;height:36px;border-radius:99px;border:none;background:rgba(255,255,255,.92);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.12)}

.why-section{background:var(--tint-1);padding:56px 28px}
.why-tile{background:#fff;border-radius:18px;padding:24px;border:1px solid #EFE7DA}
.why-tile .icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px}

.banner{background:var(--grad-banner);border-radius:26px;padding:38px;color:#fff;display:flex;flex-wrap:wrap;gap:26px;align-items:center;justify-content:space-between}
.banner .big-price{font-family:var(--serif);font-style:italic;font-size:64px;font-weight:600;opacity:.9}

.review-card{background:#fff;border-radius:18px;padding:24px;border:1px solid var(--border-card)}
.review-card .stars{color:var(--orange);font-size:15px;margin-bottom:12px;letter-spacing:2px}
.review-card p{font-size:15px;line-height:1.6;color:#3f4446;margin:0 0 18px}
.review-card .who{display:flex;align-items:center;gap:11px}
.review-card .init{width:38px;height:38px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:var(--ink)}

.dark-band{background:#211E1B;border-radius:26px;padding:40px;color:#fff;display:flex;flex-wrap:wrap;gap:30px;align-items:center;justify-content:space-between}
.dark-band .chip-dark{display:inline-flex;align-items:center;gap:8px;background:rgba(230,126,34,.16);color:var(--orange-light);font-weight:700;font-size:12px;padding:5px 12px;border-radius:99px;margin-bottom:16px}
.dark-band .stat{background:#38332e;border-radius:16px;padding:18px 22px;text-align:center;min-width:96px}

.map-fake{border-radius:20px;overflow:hidden;border:1px solid var(--border-card);min-height:260px;background:linear-gradient(135deg,#E8EDE0,#F1EEE7);position:relative;display:flex;align-items:center;justify-content:center}
.map-fake .gridlines{position:absolute;inset:0;background-image:linear-gradient(#dfe3d6 1px,transparent 1px),linear-gradient(90deg,#dfe3d6 1px,transparent 1px);background-size:34px 34px;opacity:.6}
.map-fake .pin{width:44px;height:44px;border-radius:99px 99px 99px 2px;background:var(--red);transform:rotate(45deg);margin:0 auto 14px;box-shadow:0 10px 24px rgba(192,57,43,.4)}

.footer{background:#211E1B;color:#c8c2b9;padding:44px 28px}
.footer .cols{max-width:1180px;margin:0 auto;display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between}
.footer .col-title{color:#fff;font-weight:700;font-size:14px;margin-bottom:12px}
.footer .links{display:flex;flex-direction:column;gap:9px;font-size:13.5px}
.footer .bottom{max-width:1180px;margin:26px auto 0;padding-top:20px;border-top:1px solid #38332e;font-size:12.5px;color:#8b857d}

/* ============ MENU ============ */
.search-box{flex:1;min-width:180px;display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border-input);border-radius:12px;padding:10px 14px;max-width:420px}
.search-box input{border:none;outline:none;background:none;font-size:14.5px;width:100%;color:var(--ink)}
.cart-btn{position:relative;border:1px solid var(--border-input);background:#fff;font-weight:700;font-size:14px;padding:10px 16px;border-radius:12px;cursor:pointer;display:inline-flex;color:var(--ink)}
.cart-btn .badge{position:absolute;top:-7px;right:-7px;background:var(--red);color:#fff;font-size:11px;font-weight:800;min-width:19px;height:19px;border-radius:99px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.cat-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:16px}
.cat-chip{white-space:nowrap;border:1px solid var(--border-input);background:#fff;color:#5b5f62;font-weight:700;font-size:13.5px;padding:9px 16px;border-radius:99px;cursor:pointer;display:inline-block}
.cat-chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.diet-pill{border:none;background:#F4EFE8;color:#6a6f72;font-weight:700;font-size:12.5px;padding:8px 14px;border-radius:99px;cursor:pointer;display:inline-block}
.diet-pill.active{background:var(--orange);color:#fff}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}

/* ============ KOSZYK / CHECKOUT ============ */
.order-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;align-items:start}
.cart-row{display:flex;align-items:center;gap:14px;padding:16px 22px;border-bottom:1px solid #F7F4EE}
.cart-thumb{width:64px;height:64px;flex:0 0 64px;border-radius:14px}
.qty-stepper{display:flex;align-items:center;gap:6px;background:#F4EFE8;border-radius:99px;padding:4px}
.qty-stepper button{width:28px;height:28px;border:none;border-radius:99px;background:#fff;font-weight:800;font-size:15px;cursor:pointer;color:var(--ink)}
.qty-stepper .qty{min-width:20px;text-align:center;font-weight:800;font-size:14px}
.slot-btn{border:1px solid var(--border-input);background:#fff;color:#5b5f62;font-weight:700;font-size:13px;padding:10px 15px;border-radius:11px;cursor:pointer}
.slot-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pay-card{display:flex;align-items:center;gap:11px;border:1.5px solid var(--border-input);background:#fff;border-radius:14px;padding:14px;cursor:pointer}
.pay-card.active{border-color:var(--orange);background:var(--tint-3)}
.pay-card .radio{width:19px;height:19px;border-radius:99px;border:2px solid #cfc8bd;display:flex;align-items:center;justify-content:center;flex:0 0 19px}
.pay-card.active .radio{border-color:var(--orange)}
.pay-card .radio i{width:9px;height:9px;border-radius:99px;background:transparent;display:block}
.pay-card.active .radio i{background:var(--orange)}
.summary{background:#fff;border-radius:20px;border:1px solid var(--border-card);padding:24px;position:sticky;top:90px;box-shadow:var(--shadow-elev)}
.summary .row{display:flex;justify-content:space-between;font-size:14.5px}
.points-chip{display:flex;align-items:center;gap:9px;background:var(--olive-tint);border-radius:12px;padding:12px 14px;font-size:13.5px;color:var(--success-2);font-weight:700}

/* ============ ŚLEDZENIE ============ */
.track-hero{background:linear-gradient(120deg,#E67E22,#C0392B);border-radius:24px;padding:32px;color:#fff;margin-bottom:24px;text-align:center}
.track-hero .h{font-size:34px;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.tl-row{display:flex;gap:16px}
.tl-col{display:flex;flex-direction:column;align-items:center}
.tl-dot{width:34px;height:34px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex:0 0 34px;border:2px solid transparent}
.tl-dot.done{background:var(--olive);color:#fff}
.tl-dot.active{background:var(--orange);color:#fff;animation:pulseDot 1.4s ease-in-out infinite}
.tl-dot.pending{background:#fff;border-color:#E1DDD4;color:#c4bdb2}
.tl-line{width:2px;flex:1;min-height:26px;background:var(--border-input);margin:4px 0}
.tl-line.done{background:var(--olive)}
.tl-body{padding-bottom:20px;flex:1}

/* ============ PANEL KLIENTA ============ */
.stat-card{background:#fff;border-radius:18px;border:1px solid var(--border-card);padding:20px}
.stat-card .val{font-size:28px;font-weight:800;letter-spacing:-.02em}
.dark-card{background:#211E1B;color:#fff;border-radius:20px;padding:24px}
.dark-card .label{font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--orange-light)}
.dark-card .badge{background:rgba(230,126,34,.2);color:var(--orange-light);font-size:12px;font-weight:800;padding:4px 10px;border-radius:99px}
.activity-row{display:flex;align-items:center;gap:13px;padding:12px 0;border-bottom:1px solid #F7F4EE}

/* ============ LOJALNOŚĆ ============ */
.member-card{background:linear-gradient(120deg,#211E1B,#3a332c);border-radius:24px;padding:30px;color:#fff;margin-bottom:24px;position:relative;overflow:hidden}
.member-card .glow{position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:99px;background:radial-gradient(circle,rgba(230,126,34,.35),transparent 70%)}
.member-card .pts{font-size:46px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.progress{height:10px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden}
.progress .fill{height:100%;background:linear-gradient(90deg,#E67E22,#F2A65A);border-radius:99px}
.tier-card{background:#fff;border-radius:16px;border:1.5px solid var(--border-card);padding:16px;text-align:center}
.tier-card.active{border-color:var(--orange)}
.tier-card .disc{width:34px;height:34px;border-radius:99px;margin:0 auto 10px}
.reward-card{background:#fff;border-radius:18px;border:1px solid var(--border-card);padding:18px;display:flex;flex-direction:column}
.reward-card .icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:12px}
.ach{border-radius:16px;padding:16px 10px;text-align:center}
.referral{background:linear-gradient(120deg,#6B8E23,#8BAE3D);border-radius:20px;padding:24px;color:#fff}
.referral .code{display:flex;gap:8px;background:rgba(255,255,255,.16);border-radius:12px;padding:6px 6px 6px 16px;align-items:center}

/* ============ PROFIL ============ */
.settings-nav{flex:1 1 240px;max-width:280px;background:#fff;border-radius:18px;border:1px solid var(--border-card);padding:10px;display:flex;flex-direction:column;gap:2px}
.settings-nav .head{display:flex;align-items:center;gap:11px;padding:16px;border-bottom:1px solid #F4F1EA;margin-bottom:6px}
.settings-nav .item{color:#5b5f62;font-weight:600;font-size:14px;padding:11px 14px;border-radius:11px;cursor:pointer}
.settings-nav .item.active{background:#F4EFE8;color:var(--warning);font-weight:700}
.danger-zone{background:#FDF3F1;border:1px solid #F3D9D4;border-radius:20px;padding:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.notif-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #F7F4EE;gap:14px}
.notif-row:last-child{border-bottom:none}

/* ============ ADMIN ============ */
.admin-wrap{background:var(--bg-alt);min-height:100vh;display:flex;animation:riseIn .4s ease both}
.sidebar{flex:0 0 240px;background:#211E1B;color:#c8c2b9;padding:22px 16px;display:flex;flex-direction:column}
.sidebar .brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:16px;color:#fff;padding:6px 8px 20px;border-bottom:1px solid #38332e;margin-bottom:16px}
.sidebar .sec{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6f685f;padding:6px 10px;margin-bottom:4px}
.sidebar .nav-item{font-weight:600;font-size:14px;padding:11px 12px;border-radius:11px;margin-bottom:3px;display:flex;align-items:center;gap:10px;cursor:pointer;color:#c8c2b9}
.sidebar .nav-item.active{background:var(--orange);color:#fff;font-weight:700}
.sidebar .user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid #38332e}
.admin-main{flex:1;padding:26px 30px 50px;min-width:0}
.kpi{background:#fff;border-radius:16px;border:1px solid #EFEAE1;padding:18px}
.kpi .val{font-size:26px;font-weight:800;letter-spacing:-.02em}
.kpi .delta{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-weight:800;font-size:12px;padding:3px 9px;border-radius:99px}
.panel{background:#fff;border-radius:18px;border:1px solid #EFEAE1;padding:22px}
.bars{display:flex;align-items:flex-end;gap:12px;height:180px}
.bars .bar{width:100%;background:linear-gradient(180deg,#E67E22,#F2A65A);border-radius:8px 8px 0 0;min-height:6px}
.hbar{height:8px;background:#F4F1EA;border-radius:99px;overflow:hidden}
.hbar .fill{height:100%;background:linear-gradient(90deg,#C0392B,#E67E22);border-radius:99px}
.heat{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}
.heat div{aspect-ratio:1;border-radius:7px}
.tbl-head{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:8px 12px;font-size:11px;color:var(--faint);font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding-bottom:10px;border-bottom:1px solid #F4F1EA}
.tbl-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:8px 12px;font-size:13.5px;align-items:center;padding:11px 0;border-bottom:1px solid #F7F4EE}
.status-pill{font-weight:700;font-size:11.5px;padding:4px 10px;border-radius:99px;white-space:nowrap}
.seg{display:flex;background:#fff;border:1px solid var(--border-input);border-radius:11px;padding:3px}
.seg a{color:var(--muted);font-weight:700;font-size:12.5px;padding:7px 13px;border-radius:8px}
.seg a.active{background:var(--ink);color:#fff}
@media(max-width:900px){.admin-wrap{flex-direction:column}.sidebar{flex:none;flex-direction:row;flex-wrap:wrap;align-items:center;gap:4px}.sidebar .brand{border:none;padding:6px 8px;margin:0}.sidebar .sec,.sidebar .user{display:none}}

/* ============ REZERWACJA ============ */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{font-size:11px;color:var(--faint);font-weight:700;text-align:center;margin-bottom:6px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border-card);background:#fff;color:var(--ink);font-weight:700;font-size:13.5px;cursor:pointer}
.cal-day.past{background:transparent;border-color:transparent;color:#cfc8bd;cursor:default}
.cal-day.blank{background:transparent;border-color:transparent;cursor:default}
.cal-day.sel{background:var(--orange);border-color:var(--orange);color:#fff}
.time-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:9px}
.time-btn{border:1px solid var(--border-input);background:#fff;color:#5b5f62;font-weight:700;font-size:13.5px;padding:11px;border-radius:11px;cursor:pointer}
.time-btn.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.guest-stepper{display:flex;align-items:center;gap:14px;background:#F4EFE8;border-radius:99px;padding:5px}
.guest-stepper button{width:34px;height:34px;border:none;border-radius:99px;background:#fff;font-weight:800;font-size:18px;cursor:pointer}
.res-summary{background:#211E1B;color:#fff;border-radius:20px;padding:26px;position:sticky;top:20px}
.res-summary .tile{width:42px;height:42px;border-radius:12px;background:#38332e;display:flex;align-items:center;justify-content:center;font-size:18px;flex:0 0 auto}

/* ============ LOGOWANIE ============ */
.auth-split{background:var(--bg);min-height:100vh;display:flex;flex-wrap:wrap;animation:riseIn .4s ease both}
.brand-panel{flex:1 1 340px;min-height:420px;background:linear-gradient(150deg,#C0392B,#E67E22);color:#fff;padding:44px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.brand-panel .circle{position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;border-radius:99px;background:rgba(255,255,255,.08)}
.brand-panel .quote{font-family:var(--serif);font-style:italic;font-size:40px;line-height:1.1;font-weight:500;margin-bottom:16px}
.auth-card{width:100%;max-width:388px;background:#fff;border:1px solid var(--border-card);border-radius:22px;padding:32px;box-shadow:0 24px 60px rgba(45,52,54,.08)}
.seg-tabs{display:flex;background:#F4EFE8;border-radius:13px;padding:4px;margin-bottom:26px}
.seg-tabs button{flex:1;border:none;background:transparent;color:var(--faint);font-weight:700;font-size:14px;padding:11px;border-radius:10px;cursor:pointer;transition:all .15s}
.seg-tabs button.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px rgba(45,52,54,.08)}
.divider{display:flex;align-items:center;gap:12px;color:var(--fainter);font-size:12px;margin-bottom:16px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border-div)}

/* ============ DESIGN SYSTEM ============ */
.swatch{height:70px;border-radius:14px}
.spinner{width:28px;height:28px;border-radius:99px;border:3px solid #F0ECE4;border-top-color:var(--orange);animation:spin .8s linear infinite}
.skeleton{background:linear-gradient(90deg,#F0ECE4 25%,#FAF7F1 50%,#F0ECE4 75%);background-size:400px 100%;animation:shimmer 1.3s linear infinite;border-radius:10px}
.avatar-stack{display:flex}
.avatar-stack .avatar{margin-left:-10px;border:2px solid #fff}
.avatar-stack .avatar:first-child{margin-left:0}
.toast{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;font-weight:700;font-size:13.5px;padding:13px 18px;border-radius:13px;box-shadow:0 14px 30px rgba(45,52,54,.25)}
.modal-demo{background:#fff;border-radius:20px;padding:26px;max-width:380px;box-shadow:0 24px 60px rgba(45,52,54,.18);border:1px solid var(--border-card)}

/* pomocnicze */
.mut{color:var(--muted)}
.fnt{color:var(--faint)}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;align-items:start}
.grid-2-lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;align-items:start}
.flex{display:flex}
.aic{align-items:center}
.jcsb{justify-content:space-between}
.wrap{flex-wrap:wrap}
.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}.g14{gap:14px}
.mb0{margin-bottom:0}.mb6{margin-bottom:6px}.mb10{margin-bottom:10px}.mb14{margin-bottom:14px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb22{margin-bottom:22px}.mb26{margin-bottom:26px}
