/* ═══════════════════════════════════════════════════
   FABO Creative Portal — v4
   Fixes: sidebar toggle all screens | zone editor | fonts
═══════════════════════════════════════════════════ */

@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-Regular.ttf');font-weight:400}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-Medium.ttf');font-weight:500}
@font-face{font-family:'Gilroy';src:url('../fonts/gilroy-semibold.ttf');font-weight:600}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-Bold.ttf');font-weight:700}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-ExtraBold.otf');font-weight:800}
@font-face{font-family:'Gilroy';src:url('../fonts/Gilroy-Heavy.ttf');font-weight:900}
@font-face{font-family:'GalanoGrotesque';src:url('../fonts/galanogrotesquebold.otf');font-weight:700}
@font-face{font-family:'GalanoGrotesque';src:url('../fonts/galanogrotesquemedium.otf');font-weight:500}
@font-face{font-family:'GalanoGrotesque';src:url('../fonts/GalanoGrotesqueSemiBold.otf');font-weight:600}
@font-face{font-family:'GalanoGrotesqueAlt';src:url('../fonts/galanogrotesquealtextrabold.otf');font-weight:800}
@font-face{font-family:'ArialBold';src:url('../fonts/arialbd.ttf');font-weight:700}
@font-face{font-family:'ArialBlack';src:url('../fonts/ariblk.ttf');font-weight:900}

/* Light Theme */
:root{
  --purple:#3b0764;--purple2:#6d28d9;--purple3:#7c3aed;--purple-soft:#ede9fe;
  --pink:#ec4899;--green:#22c55e;--red:#ef4444;--orange:#f97316;--blue:#3b82f6;
  --bg:#f5f3ff;--surface:#fff;--surface2:#fafafa;--surface3:#f3f4f6;
  --border:#e5e7eb;--border2:#d1d5db;--text:#111827;--text-muted:#6b7280;--text-light:#9ca3af;
  --sidebar-bg:#3b0764;--topbar-bg:#fff;--topbar-border:#e5e7eb;--card-bg:#fff;
  --input-bg:#fff;--input-border:#e5e7eb;--input-focus:#7c3aed;
  --sidebar-w:260px;--topbar-h:64px;--radius:12px;--radius-sm:8px;--radius-xs:6px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.05);--shadow-sm:0 2px 6px rgba(0,0,0,.07);
  --shadow:0 4px 16px rgba(0,0,0,.09);--shadow-md:0 8px 30px rgba(0,0,0,.11);
  --shadow-purple:0 4px 18px rgba(124,58,237,.22);--transition:.25s ease;
  --font:'Gilroy','Inter',sans-serif;
}
[data-theme="dark"]{
  --bg:#0c0618;--surface:#1a1035;--surface2:#221543;--surface3:#2a1b50;
  --border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.14);
  --text:#f0eeff;--text-muted:#a89fc0;--text-light:#6b5f85;
  --sidebar-bg:#0a0418;--topbar-bg:#130b2a;--topbar-border:rgba(255,255,255,.07);
  --card-bg:#1a1035;--input-bg:#221543;--input-border:rgba(255,255,255,.12);
  --shadow-xs:0 1px 3px rgba(0,0,0,.4);--shadow-sm:0 2px 6px rgba(0,0,0,.5);
  --shadow:0 4px 16px rgba(0,0,0,.5);--shadow-md:0 8px 30px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.6;transition:background .25s ease,color .25s ease}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}
button{font-family:var(--font)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

/* ═══════════════════════════════════════════════════
   SIDEBAR — slides off/on for ALL screen sizes
═══════════════════════════════════════════════════ */
.sidebar{
  width:var(--sidebar-w);
  background:var(--sidebar-bg);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:200;
  /* Default: visible on desktop */
  transform:translateX(0);
  transition:transform var(--transition),background .25s ease;
  overflow-y:auto;overflow-x:hidden;
}
/* When sidebar-hidden class is set (desktop collapse) */
.sidebar.sidebar-hidden{
  transform:translateX(-100%);
}
/* Mobile: start hidden, open class shows it */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:6px 0 32px rgba(0,0,0,.45)}
}

[data-theme="dark"] .sidebar{border-right:1px solid rgba(255,255,255,.05)}

.sidebar-logo-wrap{
  padding:1rem 1.25rem;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;min-height:76px;
}
.sidebar-logo-img{width:160px;height:auto;display:block;object-fit:contain;}
.sidebar-section-label{padding:.85rem 1.25rem .3rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.25);}
.sidebar-nav{flex:1;padding:.5rem .75rem;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .9rem;border-radius:9px;color:rgba(255,255,255,.55);font-size:.875rem;font-weight:500;transition:all var(--transition);cursor:pointer;}
.nav-item i{font-size:1.05rem;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.09);color:#fff}
.nav-item.active{background:var(--pink);color:#fff;box-shadow:0 3px 12px rgba(236,72,153,.4)}
.nav-divider{height:1px;background:rgba(255,255,255,.07);margin:.6rem 0}
.nav-logout:hover{background:rgba(239,68,68,.15)!important;color:#f87171!important}

/* ═══════════════════════════════════════════════════
   MAIN CONTENT — shifts with sidebar
═══════════════════════════════════════════════════ */
.main-content{
  margin-left:var(--sidebar-w);
  flex:1;display:flex;flex-direction:column;min-height:100vh;
  transition:margin-left var(--transition);
}
/* When sidebar is collapsed on desktop */
.sidebar-hidden ~ .main-content,
body.sidebar-collapsed .main-content{
  margin-left:0;
}
@media(max-width:768px){
  .main-content{margin-left:0!important}
}

/* ═══════════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════════ */
.topbar{
  background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);
  height:var(--topbar-h);padding:0 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
  transition:background .25s ease,border-color .25s ease;
  gap:.75rem;
}
.topbar-left{display:flex;align-items:center;gap:.75rem;flex-shrink:0}

/* Hamburger — ALWAYS visible, ALL screen sizes */
.hamburger{
  display:flex;align-items:center;justify-content:center;
  background:none;border:1.5px solid var(--border);
  font-size:1.3rem;color:var(--text-muted);
  cursor:pointer;width:38px;height:38px;border-radius:8px;
  transition:all var(--transition);flex-shrink:0;
}
.hamburger:hover{background:var(--purple-soft);border-color:var(--purple3);color:var(--purple3)}
[data-theme="dark"] .hamburger{border-color:rgba(255,255,255,.15)}
[data-theme="dark"] .hamburger:hover{background:rgba(124,58,237,.15)}

.topbar-logo-wrap{display:flex;align-items:center;flex-shrink:0}
.topbar-logo-img{height:44px;width:auto;display:block;object-fit:contain;}

.topbar-center{flex:1;max-width:340px;position:relative;margin:0 .75rem}
.topbar-search-icon{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:.875rem;pointer-events:none}
.topbar-search-input{width:100%;padding:.5rem 1rem .5rem 2.4rem;border:1.5px solid var(--input-border);border-radius:20px;font-size:.85rem;font-family:var(--font);background:var(--surface3);color:var(--text);outline:none;transition:all var(--transition)}
.topbar-search-input:focus{border-color:var(--purple3);background:var(--surface);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.topbar-search-input::placeholder{color:var(--text-light)}

.topbar-right{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.theme-toggle-btn{width:36px;height:36px;background:var(--surface3);border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;color:var(--text-muted);transition:all var(--transition);flex-shrink:0}
.theme-toggle-btn:hover{border-color:var(--purple3);color:var(--purple3);background:rgba(124,58,237,.08);transform:rotate(15deg)}
.topbar-user-block{display:flex;align-items:center;gap:.55rem;flex-shrink:0}
.topbar-avatar{width:34px;height:34px;background:linear-gradient(135deg,var(--purple),var(--purple3));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}
.topbar-user-name{font-weight:600;font-size:.85rem;color:var(--text);line-height:1.2;white-space:nowrap}
.topbar-user-role{font-size:.68rem;color:var(--text-muted)}
.topbar-logout-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border:1.5px solid var(--border);border-radius:7px;font-size:.78rem;font-weight:600;color:var(--text-muted);background:none;cursor:pointer;transition:all var(--transition);font-family:var(--font);text-decoration:none;white-space:nowrap;flex-shrink:0}
.topbar-logout-btn:hover{border-color:var(--red);color:var(--red)}

/* Mobile search */
.topbar-mobile-search-btn{display:none;width:34px;height:34px;background:var(--surface3);border:1.5px solid var(--border);border-radius:50%;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;color:var(--text-muted);transition:all var(--transition);flex-shrink:0}
.topbar-mobile-search-bar{display:none;align-items:center;gap:.6rem;padding:.55rem 1rem;background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);position:sticky;top:var(--topbar-h);z-index:99;}
.topbar-mobile-search-bar.open{display:flex}

/* Sidebar overlay (mobile) */
#sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:199;display:none;backdrop-filter:blur(3px);}

/* ═══════════════════════════════════════════════════
   LOGIN PAGE
═══════════════════════════════════════════════════ */
.login-page{min-height:100vh;display:flex}
.login-left{width:46%;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:2.5rem;color:#fff}
.login-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.login-left.user-theme{background:#1a0533}
.login-left.user-theme .login-bg-img{opacity:.38;object-position:center top}
.login-left.user-theme .login-gradient{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(59,7,100,.75) 0%,rgba(59,7,100,.38) 40%,rgba(236,72,153,.28) 75%,rgba(59,7,100,.90) 100%)}
.login-left.admin-theme{background:#060610}
.login-left.admin-theme .login-bg-img{opacity:.15;filter:grayscale(50%)}
.login-left.admin-theme .login-gradient{position:absolute;inset:0;background:linear-gradient(145deg,rgba(6,6,16,.92) 0%,rgba(15,15,40,.58) 45%,rgba(124,58,237,.18) 75%,rgba(6,6,16,.95) 100%)}
.login-logo-area{position:relative;z-index:3}
.login-fabo-img{height:80px;width:auto;display:block;object-fit:contain;}
.login-hero{position:relative;z-index:3;flex:1;display:flex;flex-direction:column;justify-content:center;padding:2rem 0}
.login-hero h1{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:2rem;font-weight:700;color:#fff;line-height:1.25;margin-bottom:.9rem}
.login-hero p{font-size:.88rem;color:rgba(255,255,255,.68);line-height:1.8;max-width:360px}
.login-stats{position:relative;z-index:3;display:flex;gap:2.5rem}
.ls-val{font-size:2rem;font-weight:800;color:#fff;line-height:1;font-family:'GalanoGrotesque','Gilroy',sans-serif}
.ls-lbl{font-size:.72rem;color:rgba(255,255,255,.48);margin-top:2px}
.login-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--surface2);transition:background .25s ease}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:2.5rem;width:100%;max-width:430px;box-shadow:var(--shadow-md);transition:background .25s ease,border-color .25s ease}
.login-top-bar{display:flex;justify-content:flex-end;margin-bottom:.75rem}
.login-tabs{display:flex;background:var(--surface3);border:1px solid var(--border);border-radius:10px;padding:4px;gap:2px;margin-bottom:1.75rem}
.login-tab{flex:1;padding:.55rem;text-align:center;border-radius:7px;font-size:.875rem;font-weight:600;cursor:pointer;color:var(--text-muted);transition:all var(--transition);border:none;background:none;font-family:var(--font)}
.login-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}
.login-card h2{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:.3rem}
.login-subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem}
.login-footer-note{margin-top:1.2rem;text-align:center;font-size:.8rem;color:var(--text-muted)}
.login-footer-note a{color:var(--purple3);font-weight:600}
.login-terms{margin-top:1.2rem;text-align:center;font-size:.73rem;color:var(--text-light)}
.login-terms a{color:var(--purple3)}
.btn-login{width:100%;padding:.8rem;background:var(--purple);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;font-weight:700;cursor:pointer;margin-top:1.2rem;transition:all var(--transition)}
.btn-login:hover{background:#4c1d95;transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,7,100,.32)}

/* ═══════════════════════════════════════════════════
   FORMS
═══════════════════════════════════════════════════ */
.form-label{font-size:.78rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;display:block;text-transform:uppercase;letter-spacing:.4px}
.form-control,.form-select{width:100%;padding:.7rem .9rem;border:1.5px solid var(--input-border);border-radius:var(--radius-sm);font-family:var(--font);font-size:.875rem;color:var(--text);background:var(--input-bg);outline:none;transition:border-color var(--transition),box-shadow var(--transition),background .25s ease,color .25s ease}
.form-control:focus,.form-select:focus{border-color:var(--input-focus);box-shadow:0 0 0 3px rgba(124,58,237,.13)}
.form-control::placeholder{color:var(--text-light)}
.form-select option{background:var(--surface);color:var(--text)}
textarea.form-control{resize:vertical;min-height:80px}
.form-control-number{border-color:rgba(249,115,22,.4)!important}
.form-control-number:focus{border-color:var(--orange)!important;box-shadow:0 0 0 3px rgba(249,115,22,.13)!important}
.input-wrap{position:relative}
.input-wrap .form-control{padding-right:2.75rem}
.input-eye{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem}
.form-check{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.form-check input[type=checkbox]{width:16px;height:16px;border-radius:4px;accent-color:var(--purple3);cursor:pointer;flex-shrink:0}
.form-check-label{font-size:.8rem;color:var(--text-muted);cursor:pointer;user-select:none}
.field-type-hint{font-size:.7rem;margin-top:4px;display:flex;align-items:center;gap:4px;font-weight:500}
.field-type-hint.number-hint{color:var(--orange)}
.field-type-hint.text-hint{color:var(--purple3)}

/* ═══════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.58rem 1.15rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none;white-space:nowrap;user-select:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--purple);color:#fff}.btn-primary:hover{background:#4c1d95;color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-purple)}
.btn-pink{background:var(--pink);color:#fff}.btn-pink:hover{background:#db2777;color:#fff;transform:translateY(-1px)}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#16a34a;color:#fff}
.btn-red-outline{background:transparent;border:1.5px solid var(--red);color:var(--red)}.btn-red-outline:hover{background:var(--red);color:#fff}
.btn-outline{background:transparent;border:1.5px solid var(--border2);color:var(--text-muted)}.btn-outline:hover{border-color:var(--purple3);color:var(--purple3)}
.btn-soft-purple{background:rgba(124,58,237,.1);color:var(--purple3);border:none}.btn-soft-purple:hover{background:var(--purple3);color:#fff}
.btn-soft-danger{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}.btn-soft-danger:hover{background:var(--red);color:#fff}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:#ea580c;color:#fff}
.btn-sm{padding:.35rem .8rem;font-size:.78rem;border-radius:var(--radius-xs)}
.btn-lg{padding:.8rem 2rem;font-size:.95rem}
.btn-full{width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}

/* ═══════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════ */
.app-wrapper{display:flex;min-height:100vh;background:var(--bg);transition:background .25s ease}
.page-body{padding:1.75rem;flex:1}
.page-title{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:1.45rem;font-weight:700;color:var(--text);margin-bottom:1.5rem}

/* ═══════════════════════════════════════════════════
   CARDS
═══════════════════════════════════════════════════ */
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-xs);transition:background .25s ease,border-color .25s ease}
.card-header{padding:1rem 1.35rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:transparent;flex-wrap:wrap;gap:.5rem}
.card-header h5{font-size:.95rem;font-weight:700;color:var(--text);margin:0;display:flex;align-items:center;gap:.5rem}
.card-body{padding:1.35rem}
.card-body-flush{padding:0}
.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem 1.4rem;position:relative;overflow:hidden;box-shadow:var(--shadow-xs);transition:transform var(--transition),box-shadow var(--transition),background .25s ease}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--sc,var(--purple3))}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.65px;color:var(--text-muted);margin-bottom:.55rem}
.stat-value{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:2rem;font-weight:800;color:var(--text);line-height:1}
.stat-sub{font-size:.72rem;color:var(--text-muted);margin-top:.3rem}
.stat-icon,.stat-icon-wrap{position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.stat-icon{background:var(--sib,rgba(124,58,237,.1));color:var(--sc,var(--purple3))}
.stat-icon-wrap.purple{background:rgba(124,58,237,.12);color:var(--purple3)}
.stat-icon-wrap.green{background:rgba(34,197,94,.12);color:var(--green)}
.stat-icon-wrap.pink{background:rgba(236,72,153,.12);color:var(--pink)}
.stat-icon-wrap.blue{background:rgba(59,130,246,.12);color:var(--blue)}
.stat-icon-wrap.orange{background:rgba(249,115,22,.12);color:var(--orange)}
.stat-card.purple{--sc:var(--purple3);--sib:rgba(124,58,237,.1)}
.stat-card.pink{--sc:var(--pink);--sib:rgba(236,72,153,.1)}
.stat-card.green{--sc:var(--green);--sib:rgba(34,197,94,.1)}
.stat-card.blue{--sc:var(--blue);--sib:rgba(59,130,246,.1)}
.stat-card.orange{--sc:var(--orange);--sib:rgba(249,115,22,.1)}

/* TABLE, BADGES, ALERTS, MODALS */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.fabo-table{width:100%;border-collapse:collapse;min-width:500px}
.fabo-table thead th{background:var(--surface3);border-bottom:1px solid var(--border);padding:.78rem 1.25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.65px;color:var(--text-muted);white-space:nowrap}
.fabo-table tbody td{padding:.88rem 1.25rem;border-bottom:1px solid var(--border);font-size:.875rem;color:var(--text);vertical-align:middle}
.fabo-table tbody tr:last-child td{border-bottom:none}
.fabo-table tbody tr:hover td{background:var(--surface3)}
.badge{display:inline-flex;align-items:center;gap:3px;padding:.25rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600}
.badge-active{background:rgba(34,197,94,.12);color:#16a34a}
.badge-inactive{background:rgba(239,68,68,.12);color:#dc2626}
.badge-purple{background:rgba(124,58,237,.1);color:var(--purple3)}
.badge-pink{background:rgba(236,72,153,.1);color:#be185d}
.badge-admin{background:rgba(249,115,22,.12);color:#c2410c}
.badge-partner{background:rgba(59,130,246,.12);color:#1d4ed8}
[data-theme="dark"] .badge-active{color:#4ade80}[data-theme="dark"] .badge-inactive{color:#f87171}
[data-theme="dark"] .badge-purple{color:#a78bfa}[data-theme="dark"] .badge-admin{color:#fdba74}[data-theme="dark"] .badge-partner{color:#93c5fd}
.alert{padding:.78rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;display:flex;align-items:center;gap:.5rem;border:1px solid transparent;margin-bottom:1rem}
.alert-success{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.25);color:#16a34a}
.alert-danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.25);color:#dc2626}
.alert-info{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.25);color:#1d4ed8}
.alert-warning{background:rgba(249,115,22,.1);border-color:rgba(249,115,22,.25);color:#c2410c}
[data-theme="dark"] .alert-success{color:#4ade80}[data-theme="dark"] .alert-danger{color:#f87171}[data-theme="dark"] .alert-info{color:#93c5fd}
.modal-content{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;color:var(--text)!important}
.modal-header,.modal-footer{border-color:var(--border)!important;background:transparent!important}
.modal-body{background:transparent}
.modal-title{font-family:'GalanoGrotesque','Gilroy',sans-serif!important;font-size:1rem!important;font-weight:700!important;color:var(--text)!important}
.btn-close{filter:none}[data-theme="dark"] .btn-close{filter:invert(1) grayscale(1)}

/* ═══════════════════════════════════════════════════
   TEMPLATE GRIDS
═══════════════════════════════════════════════════ */
.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.template-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.category-card{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;aspect-ratio:1;box-shadow:var(--shadow-xs);transition:transform .28s ease,box-shadow .28s ease}
.category-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.category-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.category-card:hover img{transform:scale(1.04)}
.cat-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,transparent 100%);padding:1.5rem 1rem .85rem;display:flex;flex-direction:column;align-items:center}
.cat-name{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:.9rem;font-weight:700;color:#fff;text-align:center;margin-bottom:.25rem}
.cat-more{font-size:.7rem;color:rgba(255,255,255,.75)}
.template-card{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;aspect-ratio:1;box-shadow:var(--shadow-xs);transition:transform .28s ease,box-shadow .28s ease;background:var(--surface3)}
.template-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.template-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.template-card:hover img{transform:scale(1.03)}
.tpl-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.58);backdrop-filter:blur(3px);padding:.85rem;text-align:center;transform:translateY(100%);transition:transform .28s ease}
.template-card:hover .tpl-overlay{transform:translateY(0)}
.tpl-action{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:.82rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;gap:.4rem}
.tpl-quick-actions{position:absolute;top:.6rem;right:.6rem;display:flex;flex-direction:column;gap:4px;opacity:0;transform:translateX(6px);transition:all .22s ease}
.template-card:hover .tpl-quick-actions{opacity:1;transform:translateX(0)}
.tpl-icon-btn{width:32px;height:32px;background:rgba(255,255,255,.93);backdrop-filter:blur(6px);border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.82rem;color:#374151;transition:all var(--transition);box-shadow:0 2px 6px rgba(0,0,0,.15);text-decoration:none}
.tpl-icon-btn:hover{transform:scale(1.1);background:#fff}
.tpl-icon-btn.zones:hover{background:var(--purple3);color:#fff}
.tpl-icon-btn.view:hover{background:var(--blue);color:#fff}
.tpl-icon-btn.toggle:hover{background:var(--orange);color:#fff}
.tpl-icon-btn.del:hover{background:var(--red);color:#fff}

/* ═══════════════════════════════════════════════════
   UPLOAD & ZONE EDITOR
═══════════════════════════════════════════════════ */
.upload-dropzone{border:2px dashed var(--border2);border-radius:var(--radius);padding:2.5rem;text-align:center;cursor:pointer;background:var(--surface3);transition:all var(--transition)}
.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--purple3);background:rgba(124,58,237,.06)}
.upload-dropzone i{font-size:2rem;color:var(--text-muted);display:block;margin-bottom:.75rem;transition:all var(--transition)}
.upload-dropzone:hover i{color:var(--purple3);transform:translateY(-4px)}
.upload-dropzone p{font-size:.875rem;color:var(--text-muted);margin:0 0 .4rem}
.upload-dropzone small{font-size:.75rem;color:var(--text-light)}

/* Zone canvas — critical: must have position:relative for zone boxes to align correctly */
#zone-canvas-wrap{
  position:relative;
  display:inline-block;
  line-height:0;
  border-radius:var(--radius-sm);
  overflow:hidden;
  cursor:crosshair;
  box-shadow:var(--shadow);
  max-width:100%;
}
#zone-canvas-wrap img{display:block;max-width:100%;height:auto;user-select:none}
.zone-box{position:absolute;cursor:move;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;user-select:none;text-align:center}
.zone-box[data-type="text"]{border:2px dashed rgba(124,58,237,.85);background:rgba(124,58,237,.09);color:#a78bfa}
.zone-box[data-type="number"]{border:2px dashed rgba(249,115,22,.85);background:rgba(249,115,22,.09);color:#fb923c}
.zone-box[data-type="discount"]{border:2px dashed rgba(34,197,94,.85);background:rgba(34,197,94,.09);color:#4ade80}
.zone-box[data-type="logo"]{border:2px dashed rgba(236,72,153,.85);background:rgba(236,72,153,.09);color:#f472b6}
.zone-box[data-type="image"]{border:2px dashed rgba(59,130,246,.85);background:rgba(59,130,246,.09);color:#60a5fa}
.zone-box.selected{outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 0 3px rgba(124,58,237,.4)}
.zone-box .zone-label{padding:2px 6px;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.zone-resize{position:absolute;right:0;bottom:0;width:14px;height:14px;cursor:se-resize;border-radius:3px 0 0 0;background:currentColor;opacity:.8}
.zone-preview-text{position:absolute;pointer-events:none;display:flex;align-items:flex-start;justify-content:flex-start;overflow:hidden;text-align:left;padding:4px;inset:0;word-break:break-word}

/* ═══════════════════════════════════════════════════
   CREATIVE GENERATOR
═══════════════════════════════════════════════════ */
.creative-layout{display:grid;grid-template-columns:1fr 440px;gap:1.5rem;align-items:start}
.creative-preview-wrap{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.creative-preview-wrap img{width:100%;height:100%;object-fit:contain}
.preview-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.62);backdrop-filter:blur(4px);color:#fff;padding:.72rem;text-align:center;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5rem}
.creative-form-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-xs);transition:background .25s ease}
.creative-form-panel h3{font-family:'GalanoGrotesque','Gilroy',sans-serif;font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:1.25rem}
.field-group{margin-bottom:1rem}
.field-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.4px}
.discount-slider-wrap{margin-bottom:1rem}
.discount-slider-wrap label{display:block;font-size:.78rem;font-weight:600;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.4px}
input[type=range]{width:100%;height:5px;border-radius:3px;outline:none;border:none;-webkit-appearance:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--purple);border-radius:50%;border:2.5px solid #fff;box-shadow:var(--shadow-xs);cursor:pointer}
input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--purple);border-radius:50%;border:2.5px solid #fff;cursor:pointer}
.slider-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-top:6px}
.download-section{margin-top:1.25rem}
.download-section h6{font-size:.8rem;font-weight:700;color:var(--text);margin-bottom:.75rem}
.download-note{background:#fefce8;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:.75rem;font-size:.78rem;color:#92400e;margin-top:.75rem;display:flex;gap:.5rem;align-items:flex-start}
[data-theme="dark"] .download-note{background:rgba(251,191,36,.07);border-color:rgba(251,191,36,.2);color:#fcd34d}

/* ═══════════════════════════════════════════════════
   PARTNER FOOTER
═══════════════════════════════════════════════════ */
.portal-footer{background:#0d0820;position:relative;overflow:hidden;margin-top:auto;transition:background .25s ease}
[data-theme="dark"] .portal-footer{background:#050310;border-top:1px solid rgba(255,255,255,.04)}
.footer-wave-bar{height:4px;background:linear-gradient(90deg,var(--purple) 0%,var(--pink) 40%,var(--purple3) 70%,var(--purple) 100%);background-size:200% 100%;animation:waveGlow 4s ease infinite}
@keyframes waveGlow{0%,100%{background-position:0% 0%}50%{background-position:100% 0%}}
.footer-inner{padding:2rem 2rem 1.5rem;position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:1.75rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:1.25rem}
.footer-logo-img{width:160px;height:auto;display:block;object-fit:contain;margin-bottom:.9rem;}
.footer-brand-desc{font-size:.82rem;line-height:1.75;color:rgba(255,255,255,.5);max-width:220px;margin-bottom:.9rem}
.footer-brand-tags{display:flex;gap:6px;flex-wrap:wrap}
.ftag{font-size:.58rem;font-weight:700;padding:3px 9px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}
.ftag.pink{background:var(--pink);color:#fff}
.ftag.soft{background:rgba(255,255,255,.1);color:rgba(255,255,255,.75)}
.ftag.outline{border:1.5px solid rgba(255,255,255,.3);color:rgba(255,255,255,.7)}
.footer-col h6{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.28);margin-bottom:.85rem}
.footer-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.55);margin-bottom:.45rem;transition:color var(--transition),padding-left var(--transition)}
.footer-col a:hover{color:#fff;padding-left:4px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.3)}
.footer-socials{display:flex;gap:.5rem}
.footer-social{width:30px;height:30px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:6px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:.8rem;transition:all var(--transition);text-decoration:none}
.footer-social:hover{background:var(--pink);color:#fff;border-color:var(--pink)}

/* ROLE CARDS */
.role-card{flex:1;border:2px solid var(--border);border-radius:10px;padding:.85rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:.65rem}
.role-card:hover{border-color:var(--purple3)}
.role-card.sel-partner{border-color:var(--purple3);background:rgba(124,58,237,.05)}
.role-card.sel-admin{border-color:var(--pink);background:rgba(236,72,153,.05)}
.role-icon-box{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.role-title{font-weight:700;font-size:.875rem;color:var(--text)}
.role-sub{font-size:.75rem;color:var(--text-muted)}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media(max-width:1280px){.category-grid,.template-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1100px){.creative-layout{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr;gap:1.75rem}}
@media(max-width:1024px){.category-grid,.template-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:992px){.topbar-user-block .topbar-user-name,.topbar-user-block .topbar-user-role{display:none}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:6px 0 32px rgba(0,0,0,.45)}
  .sidebar.sidebar-hidden{transform:translateX(-100%)}
  .sidebar-logo-img{width:130px}
  .main-content{margin-left:0!important}
  .topbar-mobile-search-btn{display:flex}
  .topbar{padding:0 .75rem;gap:.4rem;height:58px}
  :root{--topbar-h:58px}
  .topbar-center{display:none!important}
  .topbar-logo-img{height:36px}
  .topbar-logout-btn span{display:none}
  .topbar-logout-btn{padding:.38rem .55rem}
  .topbar-avatar{width:32px;height:32px;font-size:.68rem}
  .theme-toggle-btn{width:32px;height:32px;font-size:.85rem}
  .page-body{padding:.875rem}
  .page-title{font-size:1.15rem;margin-bottom:1rem}
  .stat-card{padding:.9rem 1rem}
  .stat-value{font-size:1.55rem}
  .stat-icon,.stat-icon-wrap{width:40px;height:40px;font-size:1.1rem;right:.9rem}
  .category-grid,.template-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .creative-layout{grid-template-columns:1fr;gap:1rem}
  .creative-form-panel{padding:1rem}
  .login-left{display:none}
  .login-right{padding:1rem}
  .login-card{padding:1.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.25rem}
  .footer-inner{padding:1.25rem 1rem 1rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .form-control,.form-select{font-size:16px}
  .btn{min-height:40px}
  .nav-item{padding:.8rem .9rem}
  .modal-dialog{margin:.5rem;max-width:calc(100% - 1rem)}
  .modal-body{max-height:70vh;overflow-y:auto}
  .fabo-table thead th,.fabo-table tbody td{padding:.65rem .85rem;font-size:.8rem}
}
@media(max-width:540px){
  .category-grid,.template-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .footer-grid{grid-template-columns:1fr}
  .topbar-avatar{width:28px;height:28px;font-size:.6rem}
  .login-card{padding:1.25rem}
  .page-body{padding:.625rem}
  .stat-card{padding:.75rem .85rem}
  .stat-value{font-size:1.35rem}
}
@media(max-width:400px){
  .category-grid,.template-grid{grid-template-columns:1fr 1fr;gap:.4rem}
  .login-card{padding:1rem .875rem;border-radius:12px}
  .login-tabs .login-tab{font-size:.78rem;padding:.45rem .5rem}
}
@media(hover:none){
  .tpl-quick-actions{opacity:1!important;transform:translateX(0)!important}
  .tpl-overlay{transform:translateY(0)!important}
}


.form-control-sm{padding:.3rem .6rem!important;font-size:.78rem!important;border-radius:6px!important}
