/* Base */
:root {
  --bg:#0f172a; /* slate-900 */
  --card:#111827; /* gray-900 */
  --surface:#0b1222;
  --surface-strong:#101a31;
  --muted:#94a3b8; /* slate-400 */
  --text:#e5e7eb; /* gray-200 */
  --border:#1f2937;
  --border-strong:#273244;
  --border-soft:#21304b;
  --brand:#22c55e; /* green-500 */
  --brand-dark:#16a34a; /* green-600 */
  --accent:#38bdf8; /* sky-400 */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif}
body.modal-open{overflow:hidden}
a{color:var(--accent);text-decoration:none}
.container{max-width:min(1480px,96vw);margin:0 auto;padding:0 clamp(20px,4vw,48px)}

/* Header */
.nav{position:sticky;top:0;z-index:120;width:100%;display:flex;justify-content:center;padding:clamp(12px,1.8vw,24px) 0;background:rgba(26,39,63,.72);border-bottom:1px solid rgba(148,163,184,.18);box-shadow:0 14px 36px rgba(15,23,42,.28);backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);transition:background .3s ease, box-shadow .3s ease, border-color .3s ease;isolation:isolate}
.nav::before{content:"";position:absolute;inset:0;background:radial-gradient(140% 200% at 15% -10%,rgba(96,165,250,.32),transparent 70%),radial-gradient(130% 180% at 90% 0%,rgba(56,189,248,.22),transparent 68%),linear-gradient(135deg,rgba(59,130,246,.12),rgba(34,197,94,.1));opacity:.55;pointer-events:none;transition:opacity .3s ease}
.nav.nav-solid{background:rgba(35,51,78,.78);border-color:rgba(148,163,184,.24);box-shadow:0 22px 48px rgba(15,23,42,.32)}
.nav.nav-solid::before{opacity:.42}
.header-shell{width:100%;max-width:min(1680px,92vw);padding:0 clamp(20px,4vw,48px);display:flex;align-items:center;justify-content:space-between;gap:clamp(18px,3vw,48px)}
.nav-left{display:flex;align-items:center;gap:clamp(16px,2vw,32px);min-width:0}
.logo{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.2px;color:var(--text);text-decoration:none}
.logo-badge{width:30px;height:30px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--brand));display:grid;place-items:center;color:#041322;font-weight:800;text-transform:uppercase}
.logo-img{height:40px;width:auto;object-fit:contain;display:block}
.logo-text{display:inline-flex;align-items:center;font-weight:700;font-size:18px;letter-spacing:.2px;color:#f9fbff;text-shadow:0 8px 22px rgba(5,10,18,.55)}
.nav-info{display:flex;flex-direction:column;gap:6px;font-size:13px;color:rgba(240,244,255,.85);line-height:1.35;text-shadow:0 6px 18px rgba(3,6,12,.45)}
.nav-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;background:rgba(59,130,246,.28);color:rgba(240,248,255,.96);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 10px 24px rgba(8,13,24,.38)}
.nav-tagline{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:360px;color:rgba(226,232,240,.9)}
.nav-right{display:flex;align-items:center;gap:clamp(18px,3vw,40px);position:relative}
.nav-links{display:flex;align-items:center;gap:clamp(18px,3vw,32px);font-size:15px;font-weight:600;color:rgba(203,213,225,.92)}
.nav-links a{position:relative;color:#f8fafc;opacity:.88;padding:10px 6px;border-radius:14px;transition:color .2s ease, opacity .2s ease, box-shadow .25s ease, background .25s ease;text-shadow:0 6px 14px rgba(3,6,12,.4)}
.nav-links a::after{content:"";position:absolute;left:12px;right:12px;bottom:-8px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--accent));opacity:0;transform:scaleX(.5);transition:transform .25s ease, opacity .25s ease}
.nav-links a:hover,.nav-links a:focus-visible{opacity:1;background:rgba(59,130,246,.16);box-shadow:0 12px 28px rgba(8,13,24,.45)}
.nav-links a:hover::after,.nav-links a:focus-visible::after{opacity:1;transform:scaleX(1)}
.nav-links a.is-active{opacity:1;background:linear-gradient(135deg,rgba(59,130,246,.28),rgba(34,197,94,.2));color:#f8fafc;box-shadow:0 16px 34px rgba(4,8,16,.52)}
.nav-links a.is-active::after{opacity:1;transform:scaleX(1)}
.nav-currency{display:flex;align-items:center;gap:12px;margin-left:clamp(12px,2vw,24px);padding-left:clamp(12px,2vw,24px);border-left:1px solid rgba(148,163,184,.18)}
.nav-cur-label{font-size:12px;color:rgba(203,213,225,.88)}
.nav-currency select{border-radius:12px;border:1px solid rgba(191,219,254,.4);background:rgba(239,246,255,.92);color:#0f172a;padding:9px 14px;min-width:120px;box-shadow:0 10px 22px rgba(15,23,42,.18)}
.nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:14px;border:1px solid rgba(191,219,254,.5);background:rgba(248,250,255,.85);color:#0f172a;cursor:pointer;transition:background .2s ease, border-color .2s ease, transform .05s ease, box-shadow .2s ease;box-shadow:0 12px 26px rgba(15,23,42,.25)}
.nav-toggle:hover{background:rgba(255,255,255,.95);border-color:rgba(148,163,184,.55)}
.nav-toggle:active{transform:scale(0.97)}
.nav-toggle .icon-close{display:none}
.nav-toggle.open .icon-burger{display:none}
.nav-toggle.open .icon-close{display:block}

/* Hero */
.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center;padding:36px 0}
.hero h1{font-size:40px;line-height:1.15;margin:0 0 12px}
.hero p{margin:0 0 22px;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px}
.search-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
label{font-size:12px;color:var(--muted)}
input,select,button,textarea{border-radius:10px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:10px 12px}
button{background:var(--brand);border-color:var(--brand);color:#06120a;font-weight:700;cursor:pointer}
button:hover{background:var(--brand-dark);}
.helper{font-size:12px;color:var(--muted)}

/* Cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.place{overflow:hidden}
.img{aspect-ratio:16/9;width:100%;border-radius:12px;background:var(--surface);border:1px solid var(--border-soft);display:block;object-fit:cover}
.place h3{margin:10px 0 4px;font-size:16px}
.place .muted{color:var(--muted);font-size:13px}

.section{margin:34px 0}
.section h2{margin:0 0 12px}

/* Footer */
footer{margin-top:40px;padding:20px 0;border-top:1px solid var(--border);color:var(--muted);font-size:14px}

/* Utils */
.actions{display:flex;gap:10px;align-items:center;margin-top:12px}
.caption{margin-top:10px;color:var(--muted);font-size:14px}
.mt-14{margin-top:14px}
.mt-20{margin-top:20px}

/* Forms */
.form{display:grid;gap:12px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form button{justify-self:start}
/* Admin edit form tweaks */
.admin-form-card{padding:18px}
.admin-form-card .section-h{margin:12px 0 8px}

/* Settings page */
.settings-section{display:flex;flex-direction:column;gap:24px;margin-top:12px}
.settings-header{display:flex;flex-direction:column;gap:8px}
.settings-header h1{margin:0;font-size:28px}
.settings-header p{margin:0;color:var(--muted);font-size:14px;line-height:1.6;max-width:560px}
.settings-layout{display:flex;gap:20px;align-items:flex-start}
.settings-menu{min-width:210px;display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--surface);position:sticky;top:84px;align-self:flex-start;max-height:calc(100vh - 140px);overflow:auto}
.settings-menu__item{display:flex;gap:8px;align-items:flex-start;width:100%;padding:10px 12px;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}
.settings-menu__item:hover{border-color:var(--border-strong);background:var(--surface-strong);color:var(--text)}
.settings-menu__item.is-active{background:#2563eb;border-color:#2563eb;color:#fff;box-shadow:0 8px 18px rgba(37,99,235,0.25)}
.settings-menu__item:focus-visible{outline:2px solid rgba(59,130,246,0.6);outline-offset:3px}
.settings-menu__meta{display:flex;flex-direction:column;gap:2px}
.settings-menu__title{font-size:14px;line-height:1.25}
.settings-menu__subtitle{font-size:12px;color:var(--muted);line-height:1.3}
.settings-menu__item.is-active .settings-menu__subtitle{color:rgba(226,232,240,0.8)}
.settings-panels{flex:1;min-width:0}
.settings-panel{display:flex;flex-direction:column;gap:16px}
.settings-js .settings-panel{display:none}
.settings-js .settings-panel.is-active{display:flex}
.settings-panel__head h2{margin:0;font-size:20px}
.settings-panel__head p{margin:4px 0 0;color:var(--muted);font-size:13px}
.settings-note{padding:12px 14px;border-radius:12px;background:rgba(37,99,235,0.08);border:1px solid rgba(59,130,246,0.18);color:#cbd5f5;font-size:13px}
.settings-stack{display:flex;flex-direction:column;gap:14px}
.settings-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}
.settings-card h3{margin:0;font-size:16px}
.settings-card__desc{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.settings-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.theme-color-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.theme-color-field .color-picker{display:flex;align-items:center;gap:10px}
.theme-color-field input[type=color]{flex:0 0 46px;height:42px;padding:0;border-radius:12px;border:1px solid var(--border);background:transparent}
.theme-color-field input[type=text]{flex:1;min-width:0;text-transform:uppercase}
.color-picker__text.has-error{border-color:#f87171;box-shadow:0 0 0 1px rgba(248,113,113,0.35) inset}

/* Dashboard */
.dashboard-section{display:flex;flex-direction:column;gap:24px}
.dashboard-hero{display:grid;grid-template-columns:1.2fr 0.8fr;gap:20px;background:linear-gradient(135deg,var(--brand),var(--accent));color:#041013;position:relative;overflow:hidden}
.dashboard-hero::after{content:'';position:absolute;inset:4px;border-radius:14px;border:1px solid rgba(255,255,255,0.16);pointer-events:none}
.dashboard-hero__content{position:relative;display:flex;flex-direction:column;gap:14px}
.dashboard-hero__meta{margin:0;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(4,16,19,.7)}
.dashboard-hero__title{margin:0;font-size:30px;line-height:1.2}
.dashboard-hero__text{margin:0;font-size:14px;color:rgba(4,16,19,.78);max-width:420px}
.dashboard-hero__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto}
.dashboard-hero__actions .button-primary{box-shadow:0 12px 24px rgba(4,16,19,.18)}
.dashboard-hero__aside{position:relative;display:flex;flex-direction:column;gap:12px;align-items:flex-start;justify-content:flex-start}
.dashboard-badge{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:12px;background:rgba(4,16,19,.12);border:1px solid rgba(4,16,19,.18);color:#041013;font-weight:600;min-width:0}
.dashboard-badge--muted{background:rgba(4,16,19,.08)}
.dashboard-badge__label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(4,16,19,.55)}
.dashboard-badge__value{font-size:14px;word-break:break-word}

.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.dashboard-stat{border-radius:14px;padding:16px 18px;border:1px solid var(--border);background:var(--card);display:flex;flex-direction:column;gap:6px;min-height:96px;box-shadow:0 10px 24px rgba(8,15,26,.18)}
.dashboard-stat__value{font-size:26px;font-weight:700}
.dashboard-stat__label{font-size:13px;color:var(--muted)}
.dashboard-stat--warning{border-color:rgba(249,115,22,0.35);background:linear-gradient(180deg,rgba(249,115,22,0.16),transparent)}
.dashboard-stat--info{border-color:rgba(56,189,248,0.35);background:linear-gradient(180deg,rgba(56,189,248,0.12),transparent)}
.dashboard-stat--neutral{border-color:rgba(148,163,184,0.25)}

.dashboard-layout{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}
.dashboard-main,.dashboard-side{display:flex;flex-direction:column;gap:18px}
.dashboard-card{display:flex;flex-direction:column;gap:16px}
.dashboard-card__head h2{margin:0;font-size:18px}
.dashboard-card__head p{margin:4px 0 0;color:var(--muted);font-size:13px}

.dashboard-link-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.dashboard-link{display:flex;align-items:center;justify-content:center;padding:11px 12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text);font-weight:600;transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease}
.dashboard-link:hover{border-color:var(--accent);box-shadow:0 10px 20px rgba(56,189,248,0.15);transform:translateY(-2px)}

.dashboard-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.dashboard-list--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.dashboard-list--two{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.dashboard-list__link{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border);padding:12px 14px;border-radius:12px;background:var(--surface);color:var(--text);text-decoration:none;transition:border-color .2s ease, transform .15s ease}
.dashboard-list__link:hover{border-color:var(--accent);transform:translateX(2px)}
.dashboard-pill{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:20px;border-radius:999px;background:var(--accent);color:#021017;font-size:12px;font-weight:700;padding:0 8px}

.dashboard-tag{display:flex;align-items:center;justify-content:center;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;text-decoration:none;transition:border-color .2s ease, transform .15s ease}
.dashboard-tag:hover{border-color:var(--accent);transform:translateY(-1px)}
.dashboard-tag--danger{border-color:rgba(248,113,113,0.45);background:rgba(248,113,113,0.08);color:#fda4af}

.dashboard-announce{color:var(--muted);font-size:13px;line-height:1.55}
.dashboard-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:0}
.dashboard-meta div{padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--surface)}
.dashboard-meta dt{margin:0 0 6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.dashboard-meta dd{margin:0;font-size:14px;font-weight:600}

@media (max-width: 900px){
  .dashboard-hero{grid-template-columns:1fr;padding-bottom:26px}
  .dashboard-hero__aside{flex-direction:row;flex-wrap:wrap;gap:10px}
  .dashboard-layout{grid-template-columns:1fr}
}

@media (max-width: 640px){
  .dashboard-hero__title{font-size:26px}
  .dashboard-hero__actions{flex-direction:column;align-items:stretch}
  .dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}
  .dashboard-list--grid{grid-template-columns:1fr}
  .dashboard-link-grid{grid-template-columns:1fr}
  .dashboard-list__link{padding:12px}
  .dashboard-tag{padding:10px}
}
.settings-preview{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.settings-preview__img{display:block;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:6px;object-fit:contain}
.settings-preview__img--logo{max-width:140px;max-height:90px}
.settings-preview__img--favicon{width:48px;height:48px}
.settings-status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid currentColor;font-size:12px;font-weight:600}
.settings-status-list{display:grid;gap:8px;margin:0}
.settings-status-list dt{font-size:11px;color:rgba(148,163,184,0.8);text-transform:uppercase;letter-spacing:.08em}
.settings-status-list dd{margin:0;font-size:13px;color:var(--text)}
.settings-status-list a{color:#93c5fd;text-decoration:underline}
.settings-form{display:block}
.settings-form-footer{justify-content:flex-end;margin-top:20px}
.settings-feedback-ok{color:#34d399}
.settings-feedback-error{color:#f87171}
.settings-manual-backup{margin-top:28px;padding:20px;border-radius:14px;border:1px solid var(--border);background:var(--card);display:flex;flex-direction:column;gap:10px}
.settings-manual-backup__title{margin:0;font-size:17px}
.settings-manual-backup__actions{justify-content:flex-start}
.settings-log{white-space:pre-wrap;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;max-height:220px;overflow:auto;font-size:12px}
.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;display:none;align-items:center;justify-content:center;background:rgba(7,12,24,0.78);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:120}
.modal-backdrop.is-active{display:flex}
.modal-window{position:relative;background:var(--card);border:1px solid var(--border);border-radius:16px;max-width:520px;width:calc(100% - 32px);box-shadow:0 28px 60px rgba(0,0,0,0.42);display:flex;flex-direction:column;overflow:hidden}
.modal-content{padding:22px 22px 18px;display:flex;flex-direction:column;gap:14px}
.modal-title{margin:0;font-size:18px}
.modal-message{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.modal-meta{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.modal-meta strong{color:var(--text)}
.modal-progress{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--muted)}
.modal-progress__item{display:flex;align-items:flex-start;gap:10px;position:relative;padding-left:26px}
.modal-progress__item::before{content:'';position:absolute;left:8px;top:6px;width:10px;height:10px;border-radius:50%;border:2px solid #334155;background:#0d1629;transition:.2s}
.modal-progress__item::after{content:'';position:absolute;left:12px;top:18px;width:2px;height:calc(100% - 18px);background:rgba(148,163,184,0.4)}
.modal-progress__item:last-child::after{display:none}
.modal-progress__item.is-active::before{border-color:var(--accent);background:var(--accent)}
.modal-progress__item.is-done::before{border-color:#34d399;background:#34d399}
.modal-progress__item.is-error::before{border-color:#f87171;background:#f87171}
.modal-progress__label{display:block}
.modal-progress__time{font-size:11px;color:#64748b}
.modal-running{display:flex;align-items:center;gap:10px;font-size:13px;color:#cbd5f5}
.modal-running::before{content:'';width:16px;height:16px;border:3px solid rgba(148,163,184,0.4);border-top-color:var(--accent);border-radius:50%;animation:modal-spin 0.9s linear infinite}
.modal-log{white-space:pre-wrap;background:#050b15;border:1px solid var(--border);border-radius:10px;padding:12px;max-height:280px;overflow:auto;font-size:12px;color:#f8fafc}
.modal-log{margin-top:6px}
.modal-footer{padding:16px 22px;background:#101a2b;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px}
.modal-close{position:absolute;top:10px;right:12px;background:transparent;border:none;color:var(--muted);font-size:24px;cursor:pointer;line-height:1;padding:4px}
.modal-close:hover{color:#f1f5f9}
.modal-status{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.modal-status.is-ok{color:#34d399}
.modal-status.is-warn{color:#facc15}
.modal-status.is-error{color:#f87171}
.modal-window.has-error .modal-title{color:#f87171}
.modal-window.has-warn .modal-title{color:#facc15}
.modal-window.has-success .modal-title{color:#34d399}
@keyframes modal-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@media (max-width:1024px){.settings-layout{flex-direction:column}.settings-menu{flex-direction:row;position:relative;top:auto;max-height:none;overflow-x:auto;overflow-y:hidden;padding:10px}.settings-menu__item{flex:1 0 auto}.settings-form-footer{justify-content:flex-start}}
@media (max-width:640px){.settings-header h1{font-size:24px}.settings-menu__item{font-size:13px;padding:8px 10px}.settings-columns{grid-template-columns:1fr}.settings-manual-backup{padding:16px}}

/* Buttons (global) */
.button-primary{display:inline-block;background:#2563eb;color:#fff;border:1px solid #2563eb;padding:12px 16px;border-radius:10px;text-decoration:none;text-align:center;font-weight:700;transition:background-color .2s ease, box-shadow .2s ease}
.button-primary:hover{background:#1d4ed8;box-shadow:0 6px 16px rgba(29,78,216,.25)}
.button-outline{display:inline-block;background:transparent;color:#2563eb;border:1px solid #2563eb;padding:12px 16px;border-radius:10px;text-decoration:none;text-align:center;font-weight:700;transition:background-color .2s ease, color .2s ease, box-shadow .2s ease}
.button-outline:hover{background:#eff6ff;color:#1e40af;box-shadow:0 6px 16px rgba(30,64,175,.15)}

/* Floating cart */
.cart-fab{position:fixed;right:18px;bottom:18px;z-index:70;width:56px;height:56px;border-radius:999px;border:1px solid var(--border);background:linear-gradient(180deg,var(--card),var(--surface));color:var(--text);display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.35);cursor:pointer;transition:transform .08s ease, box-shadow .2s ease}
.cart-fab:hover{box-shadow:0 14px 36px rgba(0,0,0,.45)}
.cart-fab:active{transform:translateY(1px)}
.cart-fab-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;border-radius:999px;padding:2px 6px;font-size:12px;font-weight:700;border:1px solid #b91c1c}
.cart-drawer{position:fixed;inset:0;display:none;align-items:flex-end;justify-content:flex-end;background:rgba(0,0,0,.45);-webkit-backdrop-filter:saturate(120%) blur(2px);backdrop-filter:saturate(120%) blur(2px);z-index:69}
.cart-drawer.open{display:flex}
.cart-drawer-panel{width:min(440px,100%);background:linear-gradient(180deg,var(--card),var(--surface));border-left:1px solid var(--border);height:100%;display:flex;flex-direction:column;box-shadow:-10px 0 30px rgba(0,0,0,.35);transform:translateX(100%);transition:transform .28s ease}
.cart-drawer.open .cart-drawer-panel{transform:translateX(0)}
.cart-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 16px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--bg),var(--surface-strong))}
.cart-drawer-body{padding:16px;gap:12px;display:flex;flex-direction:column;overflow:auto}
.cart-drawer-footer{padding:14px 16px;border-top:1px solid var(--border);display:grid;gap:8px;background:linear-gradient(180deg,var(--surface-strong),var(--surface))}
.cart-close{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:999px;width:36px;height:36px;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .05s ease}
.cart-close:hover{background:var(--surface-strong);border-color:var(--border-strong)}
.cart-close:active{transform:scale(0.98)}
.cart-item-mini{display:flex;gap:12px;border:1px solid var(--border-soft);background:var(--surface);border-radius:12px;padding:10px;transition:box-shadow .2s ease, border-color .2s ease}
.cart-item-mini:hover{box-shadow:0 6px 18px rgba(0,0,0,.2);border-color:var(--border-strong)}
.cart-item-mini img{width:64px;height:64px;object-fit:cover;border-radius:10px}
.cart-item-mini .ci-title{font-weight:700}
.cart-item-mini .ci-meta{font-size:12px;color:var(--muted)}
.ci-controls{display:flex;gap:8px;align-items:center;margin-left:auto}
.ci-controls input{width:64px;border-radius:8px}
.ci-remove{border:1px solid #7f1d1d;background:linear-gradient(180deg,var(--border),var(--surface));color:#ef4444;border-radius:10px;cursor:pointer;padding:6px 8px}
.ci-update{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:10px;cursor:pointer;padding:6px 8px}

/* Responsive */
@media (max-width: 900px){
  .hero{grid-template-columns:1fr}
  .search-grid{grid-template-columns:1fr 1fr}
  .grid{grid-template-columns:1fr 1fr}
  .header-shell{flex-wrap:wrap;gap:14px;padding:0 clamp(16px,5vw,32px);align-items:center}
  .nav-left{width:auto;flex:1 1 auto;gap:12px}
  .logo{gap:10px}
  .logo-img{height:34px}
  .nav-info{display:none}
  .nav-right{flex:0 0 auto;display:flex;align-items:center;gap:10px}
  .nav-toggle{display:flex}
  .nav-links{position:absolute;top:calc(100% + 16px);right:clamp(16px,6vw,32px);display:none;flex-direction:column;align-items:flex-start;gap:18px;padding:20px;border-radius:22px;min-width:min(320px,calc(100vw - 32px));background:rgba(246,250,255,.95);border:1px solid rgba(148,163,184,.26);box-shadow:0 26px 52px rgba(15,23,42,.28);backdrop-filter:saturate(180%) blur(14px)}
  .nav-links.open{display:flex}
  .nav-links a{width:100%;padding:12px 14px;border-radius:12px;background:rgba(15,23,42,.06);color:#0f172a;box-shadow:0 8px 18px rgba(15,23,42,.12)}
  .nav-links a.is-active{box-shadow:0 12px 24px rgba(15,23,42,.16);background:linear-gradient(135deg,rgba(59,130,246,.26),rgba(34,197,94,.22));color:#0f172a}
  .nav-links a::after{display:none}
  .nav-links a:hover{background:rgba(59,130,246,.18);box-shadow:0 16px 30px rgba(15,23,42,.18)}
  .nav-currency{width:100%;margin-left:0;padding-left:0;padding-top:16px;margin-top:12px;border-left:none;border-top:1px solid rgba(148,163,184,.22);flex-direction:column;align-items:flex-start;gap:12px}
  .nav-cur-label{display:inline-block;color:#0f172a;font-weight:600}
  .nav-currency select{width:100%;background:#f8fbff;color:#0f172a;border:1px solid rgba(148,163,184,.28);box-shadow:none}
}
@media (max-width: 640px){
  .nav{padding:12px 0;background:rgba(37,54,84,.78)}
  .nav::before{opacity:.48}
  .logo-img{height:32px}
  .header-shell{gap:12px;padding:0 clamp(14px,6vw,24px)}
  .nav-right{gap:8px}
  .nav-links{top:calc(100% + 12px);min-width:min(280px,calc(100vw - 28px));padding:16px}
  .nav-links a{padding:10px 12px}
  .nav-currency{padding-top:12px;margin-top:10px}
  .nav-toggle{width:40px;height:40px;border-color:rgba(191,219,254,.55);background:rgba(252,254,255,.9);color:#0f172a}
}
@media (max-width: 560px){
  .search-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .form .row{grid-template-columns:1fr}
}
/*
 * Dosya: assets/css/style.css
 * Amaç: Tema renkleri, tipografi, grid/kart yapıları, butonlar, nav ve
 *        uçan sepet (cart-fab/cart-drawer) için genel stiller.
 */
/* Footer */
.site-footer{position:relative;margin-top:48px;padding:0;background:linear-gradient(200deg,rgba(26,39,63,.78) 0%,rgba(15,25,44,.9) 100%);border-top:1px solid rgba(148,163,184,.18);box-shadow:0 -22px 48px rgba(15,23,42,.32);overflow:hidden}
.site-footer::before,.site-footer::after{content:"";position:absolute;inset:0;pointer-events:none}
.site-footer::before{background:radial-gradient(140% 160% at -10% 8%,rgba(96,165,250,.32),transparent 62%),radial-gradient(120% 150% at 110% -12%,rgba(59,130,246,.24),transparent 68%),radial-gradient(120% 160% at 60% 120%,rgba(34,197,94,.18),transparent 72%);opacity:.65}
.site-footer::after{background:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 800 400" preserveAspectRatio="none"%3E%3Cpath d="M-40 260 C120 140 280 180 440 250 S720 360 860 220" fill="none" stroke="rgba(191,219,254,0.28)" stroke-width="30" stroke-linecap="round" stroke-dasharray="70 120"/%3E%3C/svg%3E') center/cover no-repeat;mix-blend-mode:soft-light;opacity:.4}
.site-footer>.container{position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:minmax(0,1.4fr) repeat(3,minmax(0,1fr));gap:28px;padding:40px 0 30px}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-brand .logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:#f8fbff;text-shadow:0 8px 22px rgba(15,22,38,.45)}
.footer-brand .logo img{filter:drop-shadow(0 14px 28px rgba(15,23,42,.55))}
.footer-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(191,219,254,.22);color:#e0f2fe;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 10px 24px rgba(15,23,42,.32)}
.footer-meta{display:grid;gap:8px;color:rgba(235,244,255,.88);font-size:14px;line-height:1.55;max-width:420px}
.footer-actions{display:flex;flex-wrap:wrap;gap:12px}
.footer-actions a{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;background:rgba(226,239,255,.14);color:#e0f2fe;border:1px solid rgba(191,219,254,.35);box-shadow:0 12px 26px rgba(15,23,42,.32);font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}
.footer-actions a:hover{transform:translateY(-2px);background:rgba(59,130,246,.26);box-shadow:0 18px 34px rgba(15,23,42,.42)}
.footer-col{display:flex;flex-direction:column;gap:10px;color:rgba(232,241,255,.9)}
.footer-col h4{margin:0 0 8px;font-size:15px;text-transform:uppercase;letter-spacing:.12em;color:rgba(221,239,255,.85)}
.footer-col a{color:#f8fbff;text-decoration:none;opacity:.85;transition:opacity .2s ease,transform .2s ease}
.footer-col a:hover{opacity:1;transform:translateX(2px)}
.footer-col .muted{color:rgba(203,213,225,.75)}
.footer-news{display:flex;gap:10px}
.footer-news input{flex:1;min-width:0;border:1px solid rgba(191,219,254,.28);background:rgba(248,250,255,.92);color:#0f172a;border-radius:12px;padding:10px 14px;box-shadow:0 12px 22px rgba(15,23,42,.22)}
.footer-news input::placeholder{color:rgba(71,85,105,.8)}
.footer-news button{border:1px solid rgba(191,219,254,.5);background:linear-gradient(135deg,rgba(226,239,255,.95),rgba(191,219,254,.72));color:#10243b;border-radius:12px;padding:10px 16px;font-weight:600;cursor:pointer;box-shadow:0 18px 32px rgba(15,23,42,.3);transition:transform .2s ease,box-shadow .2s ease}
.footer-news button:hover{transform:translateY(-2px);box-shadow:0 22px 40px rgba(15,23,42,.36)}
.footer-social{display:flex;align-items:center;gap:12px;margin-top:12px}
.footer-social a{width:38px;height:38px;border-radius:12px;border:1px solid rgba(191,219,254,.32);display:flex;align-items:center;justify-content:center;color:#f1f5f9;background:rgba(248,250,255,.16);box-shadow:0 12px 28px rgba(15,23,42,.28);transition:transform .2s ease,background .2s ease,border-color .2s ease}
.footer-social a:hover{transform:translateY(-2px);background:rgba(248,250,255,.28);border-color:rgba(191,219,254,.55)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:16px 0 24px;border-top:1px solid rgba(191,219,254,.22);color:rgba(224,231,255,.85);font-size:13px;gap:16px}
.footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.footer-links a, .footer-links button{color:rgba(226,238,255,.9);text-decoration:none;opacity:.85;font-size:13px;background:none;border:none;padding:0;cursor:pointer}
.footer-links a:hover,.footer-links button:hover{opacity:1}
@media (max-width: 900px){
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;padding:34px 0 24px}
  .footer-brand{grid-column:1/-1}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width: 640px){
  .site-footer .container{padding-left:20px;padding-right:20px}
  .footer-grid{grid-template-columns:1fr;gap:24px;text-align:left}
  .footer-actions{width:100%;flex-direction:column;align-items:stretch}
  .footer-actions a{justify-content:center;width:100%}
  .footer-news{flex-direction:column}
  .footer-news button{width:100%}
  .footer-bottom{align-items:flex-start;text-align:left}
  .footer-links{justify-content:flex-start}
}

/* Admin list row actions dropdown */
.row-actions{position:relative;display:inline-block}
.row-actions>summary{list-style:none;cursor:pointer}
.row-actions>summary::-webkit-details-marker{display:none}
.ra-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;box-shadow:0 14px 36px rgba(0,0,0,.3);z-index:70;display:none}
.row-actions[open] .ra-menu{display:block}
.ra-link,.ra-menu form button{display:block;width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text);cursor:pointer}
.ra-link:hover,.ra-menu form button:hover{background:var(--card);border-color:var(--border-strong)}
.ra-danger{color:#ef4444;border-color:#7f1d1d}
.ag-layout{display:flex;gap:16px;align-items:flex-start;margin-top:20px}
.agency-sidebar{position:sticky;top:20px;min-width:240px;max-width:240px;align-self:flex-start;border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface);display:flex;flex-direction:column;gap:12px}
.agency-sidebar .brand{display:flex;align-items:center;gap:10px;font-weight:800}
.agency-sidebar .logo-badge{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--accent));display:grid;place-items:center;color:#0b1020;font-weight:800}
.agency-sidebar .ag-logo{width:28px;height:28px;border-radius:8px;object-fit:cover;border:1px solid var(--border)}
.agency-sidebar .menu{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.agency-sidebar .menu a{display:block;padding:8px 10px;border:1px solid var(--border-strong);border-radius:10px;color:var(--text);text-decoration:none}
.agency-sidebar .menu a.active{background:var(--card);border-color:#334155}
.agency-sidebar .currency-switch{position:relative;display:flex;flex-direction:column;gap:6px;padding:10px;border:1px solid var(--border);border-radius:12px;background:var(--bg)}
.agency-sidebar .currency-switch label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:rgba(226,232,240,.7)}
.agency-sidebar .currency-switch .select-wrap{position:relative}
.agency-sidebar .currency-switch select{width:100%;background:var(--surface-strong);color:var(--text);border:1px solid var(--border-strong);border-radius:10px;padding:8px 34px 8px 10px;font-size:14px;appearance:none}
.agency-sidebar .currency-switch select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.35)}
.agency-sidebar .currency-switch .select-wrap::after{content:'v';position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:rgba(226,232,240,.5);font-size:12px}
.agency-content{flex:1;min-width:0}

/* Cookie consent */
.cookie-consent[hidden]{display:none!important}
.cookie-consent{position:fixed;bottom:16px;left:16px;right:16px;z-index:1100;display:flex;flex-direction:column;gap:12px;pointer-events:none}
.cookie-consent__banner,.cookie-consent__panel{background:rgba(8,13,28,0.96);border:1px solid rgba(59,130,246,0.2);border-radius:18px;padding:20px;box-shadow:0 18px 32px rgba(15,23,42,0.45);pointer-events:auto}
.cookie-consent__panel{display:flex;flex-direction:column;gap:16px}
.cookie-consent__copy{display:flex;flex-direction:column;gap:8px}
.cookie-consent__copy p{font-size:0.9rem;color:#d1d5db}
.cookie-consent__copy a{color:#60a5fa;text-decoration:underline}
.cookie-consent__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.cookie-consent__option{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid rgba(148,163,184,0.18)}
.cookie-consent__option:last-of-type{border-bottom:none}
.cookie-consent__panel h3{margin:0}
.cookie-consent__panel p{margin:0;color:#d1d5db;font-size:0.92rem}
.cookie-consent__panel-actions{display:flex;justify-content:flex-end;gap:12px}
.cookie-switch{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}
.cookie-switch input{position:absolute;opacity:0;width:0;height:0}
.cookie-switch__slider{position:relative;width:44px;height:24px;background:var(--border);border-radius:999px;transition:background .2s ease}
.cookie-switch__slider::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#f9fafb;transition:transform .2s ease}
.cookie-switch input:checked+.cookie-switch__slider{background:#2563eb}
.cookie-switch input:checked+.cookie-switch__slider::after{transform:translateX(20px)}
.cookie-switch__label{font-size:0.85rem;color:#cbd5f5}
.cookie-manage-link{background:none;border:none;color:#93c5fd;cursor:pointer;padding:0;font:inherit;text-decoration:underline}
.cookie-manage-link:hover,.cookie-manage-link:focus{color:#bfdbfe}
.cookie-manage-link:focus{outline:2px solid #2563eb;outline-offset:3px}
@media (min-width:640px){.cookie-consent{left:auto;max-width:420px}}
@media (max-width:639px){.cookie-consent{bottom:12px}.cookie-consent__actions{justify-content:stretch}.cookie-consent__actions .button-outline,.cookie-consent__actions .button-primary{flex:1 1 auto}}
