:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e7ecf5;background:#05060a;line-height:1.4;font-weight:400;--bg: #05060a;--surface: radial-gradient(circle at 20% 20%, rgba(139, 92, 246, .08), transparent 25%), radial-gradient(circle at 80% 0%, rgba(34, 211, 238, .12), transparent 25%), #05060a;--card: #0d1018;--muted: #9aa4bc;--text: #e7ecf5;--border: #1c2433;--accent: #8b5cf6;--accent-2: #22d3ee;--shadow: 0 24px 60px rgba(0, 0, 0, .35)}:root[data-theme=light]{color:#0f172a;background:#f8fafc;--bg: #f8fafc;--surface: radial-gradient(circle at 20% 20%, rgba(99, 102, 241, .08), transparent 22%), radial-gradient(circle at 80% 10%, rgba(34, 197, 235, .12), transparent 24%), #f8fafc;--card: #ffffff;--muted: #475569;--text: #0f172a;--border: #e2e8f0;--accent: #7c3aed;--accent-2: #0ea5e9;--shadow: 0 16px 40px rgba(15, 23, 42, .15)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}button,input{font:inherit;color:inherit}.page-shell{min-height:100vh;background:radial-gradient(circle at 20% 20%,rgba(139,92,246,.15),transparent 25%),radial-gradient(circle at 80% 0%,rgba(34,211,238,.2),transparent 25%),#05060a;display:flex;align-items:center;justify-content:center;padding:32px}.auth-grid{width:min(1100px,100%);background:linear-gradient(145deg,#131826e6,#080a12f2);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.2fr 1fr;overflow:hidden}.hero-pane{padding:32px;background:radial-gradient(circle at 30% 20%,rgba(139,92,246,.2),transparent 45%),radial-gradient(circle at 90% 20%,rgba(34,211,238,.2),transparent 35%),linear-gradient(160deg,#0f1628,#0b0f1c 70%);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:16px}.hero-top{display:flex;align-items:center;gap:12px;justify-content:space-between}.brand-mark{display:inline-flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;background:linear-gradient(145deg,var(--accent),var(--accent-2));color:#0b0f16}.brand-name{color:#f8fafc}.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:999px;font-size:13px;color:var(--muted)}.gallery-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:8px}.preview-card{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:16px;overflow:hidden;box-shadow:0 18px 45px #00000059;animation:floatIn .48s ease forwards;opacity:0}.preview-image{aspect-ratio:4 / 3;overflow:hidden;position:relative}.preview-image img{width:100%;height:100%;object-fit:cover;display:block}.preview-meta{padding:10px 12px 12px;display:flex;flex-direction:column;gap:4px}.preview-title{font-weight:600}.preview-photographer{color:var(--muted);font-size:13px}.hero-highlights{margin-top:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.hero-highlight{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:var(--muted);font-size:14px}.form-pane{padding:32px 28px;display:flex;justify-content:center;align-items:center}.form-card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:26px;width:min(420px,100%);box-shadow:var(--shadow)}.form-header h1{margin:0;font-size:28px}.form-header p{margin:6px 0 0;color:var(--muted)}.form{margin-top:20px;display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:8px;color:#dce3f3}.form-field span{font-weight:600}.input-wrap{display:flex;align-items:center;gap:10px;background:#ffffff05;border:1px solid var(--border);border-radius:12px;padding:12px 14px}.input-wrap input{background:transparent;border:none;outline:none;width:100%;color:#e7ecf5}.hint{color:var(--muted);font-size:13px;margin:0}.form-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.checkbox{display:inline-flex;align-items:center;gap:10px;color:var(--muted);font-size:14px}.checkbox input{width:18px;height:18px;accent-color:var(--accent)}.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.choice-card{position:relative;padding:14px;border-radius:14px;border:1px solid var(--border);background:#ffffff05;color:#e7ecf5;cursor:pointer;display:grid;gap:8px;transition:border .12s ease,transform .12s ease,box-shadow .12s ease}.choice-card input{position:absolute;opacity:0}.choice-card.selected{border-color:#8b5cf699;box-shadow:0 14px 32px #8b5cf633;transform:translateY(-2px)}.choice-heading{display:flex;align-items:center;gap:8px;font-weight:700}.pill{padding:4px 10px;border-radius:999px;background:#22d3ee1f;color:#a5f3fc;font-size:12px;font-weight:700}.pill.premium{background:#8b5cf62e;color:#e9d5ff}.primary-button,.secondary-button,.text-button{border:none;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.primary-button{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0f16;padding:12px 16px;border-radius:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 16px 45px #8b5cf640}.primary-button.ghost{background:#8b5cf61a;color:#e6ddff;box-shadow:none;border:1px solid rgba(139,92,246,.4)}.secondary-button{padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#ffffff05;color:#e7ecf5}.text-button{background:none;color:var(--accent-2);padding:0}button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.secondary-button.compact,.primary-button.compact,.text-button.compact{padding:8px 12px;font-size:14px}.primary-button:hover,.secondary-button:hover,.text-button:hover{transform:translateY(-1px)}.form-footer{color:var(--muted);text-align:center;margin:4px 0 0}.verify{text-align:center;gap:14px}.verify-icon{width:52px;height:52px;margin:0 auto;border-radius:16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);display:grid;place-items:center;color:#d6c4ff}.verify p{color:var(--muted)}.button-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:10px}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:var(--bg);color:var(--text)}.app-body{background:var(--surface);min-height:100vh;display:flex;flex-direction:column}.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--border);background:var(--card);padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);transform:translate(0);transition:transform .2s ease;z-index:25}.sidebar-brand{display:inline-flex;align-items:center;gap:12px;cursor:pointer}.sidebar-brand-text{display:flex;flex-direction:column;line-height:1.2;font-size:13px}.sidebar-brand-text strong{color:var(--text);font-size:15px}.sidebar-nav{display:flex;flex-direction:column;gap:6px;overflow-y:auto;padding-right:6px}.sidebar-link{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:var(--muted);text-decoration:none;border:1px solid transparent;transition:border-color .2s ease,background .2s ease,color .2s ease}.sidebar-link:hover{border-color:var(--border);color:var(--text)}.sidebar-link.active{color:var(--text);border-color:var(--border);background:linear-gradient(120deg,#7c3aed1f,#0ea5e91f)}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:8px}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:18;opacity:0;transition:opacity .2s ease;pointer-events:none}.app-shell.sidebar-collapsed{grid-template-columns:1fr}.app-shell.sidebar-collapsed .sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;transform:translate(-100%);z-index:20}.app-shell.sidebar-open .sidebar{transform:translate(0)}.app-shell.is-mobile.sidebar-open .sidebar-backdrop{display:block;opacity:1;pointer-events:auto}.app-shell.is-desktop .sidebar-backdrop{display:none!important;opacity:0!important;pointer-events:none!important}.topbar{position:sticky;top:0;z-index:12;display:flex;align-items:center;gap:12px;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar.compact .page-header{margin:0}.brand-stack,.topbar-actions{display:inline-flex;align-items:center;gap:8px}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer}.editor-main{max-width:1200px;width:100%;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:20px}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;transform:translate(-100%);z-index:20;border-right:none}.app-shell.sidebar-open .sidebar{transform:translate(0)}.sidebar-backdrop{display:none}.app-shell.sidebar-open .sidebar-backdrop{opacity:1;display:block}.editor-main{padding:18px}.topbar{position:sticky;top:0}.topbar-actions{gap:6px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;transform:translate(-100%)}}.page-header h1{margin:0;font-size:28px}.page-header p{margin:4px 0 0;color:var(--muted)}.stack-lg{display:flex;flex-direction:column;gap:18px}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.card-title{display:inline-flex;align-items:center;gap:8px;font-weight:700}.muted{color:var(--muted)}.muted.small{font-size:13px}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.stat-card{display:grid;gap:10px}.stat-top{display:flex;align-items:center;justify-content:space-between}.stat-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center}.stat-icon.purple{background:linear-gradient(135deg,#a855f7,#6366f1)}.stat-icon.pink{background:linear-gradient(135deg,#ec4899,#f97316)}.stat-icon.blue{background:linear-gradient(135deg,#22d3ee,#3b82f6)}.stat-icon.emerald{background:linear-gradient(135deg,#10b981,#34d399)}.stat-change{color:var(--muted);font-size:13px}.stat-body h3{margin:4px 0 0;font-size:26px}.stat-actions{display:flex;align-items:center;justify-content:space-between}.card .pill.small,.pill.small{font-size:12px;padding:4px 10px}.pill.small.emerald{background:#10b98126;color:#a7f3d0}.pill.small.pink{background:#ec489926;color:#fbcfe8}.pill.small.blue{background:#22d3ee26;color:#bae6fd}.pill.small.purple{background:#6366f126;color:#c7d2fe}.pill.small.amber{background:#f59e0b26;color:#fcd34d}.pill.small.red{background:#f8717126;color:#fecaca}.list{display:grid;gap:10px}.list-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:10px;border:1px solid var(--border);border-radius:12px}.list-body p{margin:0}.list-body .muted.small{display:block;margin-top:4px}.metrics{display:grid;gap:10px}.metric{display:grid;gap:6px}.metric-top{display:flex;align-items:center;justify-content:space-between}.metric-bar{height:8px;background:#ffffff0f;border-radius:999px;overflow:hidden}.metric-bar-fill{height:100%;border-radius:999px}.metric-bar-fill.blue{background:linear-gradient(135deg,#22d3ee,#3b82f6)}.metric-bar-fill.emerald{background:linear-gradient(135deg,#10b981,#34d399)}.metric-bar-fill.amber{background:linear-gradient(135deg,#f59e0b,#f97316)}.metric-bar-fill.purple{background:linear-gradient(135deg,#a855f7,#6366f1)}.metric-helper{color:var(--muted);font-size:13px}.filter-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.chip-filter{padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#ffffff05;color:var(--text);cursor:pointer;transition:all .12s ease}.chip-filter.active{border-color:#8b5cf680;background:#8b5cf61f;color:#e9d5ff}.chip-filter:hover{transform:translateY(-1px)}.tab-row{display:inline-flex;gap:10px;flex-wrap:wrap}.tab{padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:#ffffff05;color:var(--text);cursor:pointer;transition:all .12s ease}.tab.active{border-color:#8b5cf680;background:#8b5cf61f;color:#e9d5ff}.tab:hover{transform:translateY(-1px)}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.action-tile{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:14px;background:#ffffff05;color:var(--text);text-decoration:none}.filter-card{border:1px solid var(--border);border-radius:18px;padding:16px;background:var(--card);box-shadow:var(--shadow)}.filter-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.field label{display:block;font-size:14px;color:var(--muted);margin-bottom:6px}.form-input{width:100%;border:1px solid var(--border);background:#ffffff05;color:var(--text);border-radius:12px;padding:10px 12px}.form-input:focus{outline:2px solid rgba(139,92,246,.4)}.event-group{border:1px solid var(--border);border-radius:16px;background:var(--card);box-shadow:var(--shadow);overflow:hidden}.event-header{display:flex;align-items:center;justify-content:space-between;padding:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0f16;cursor:pointer}.event-header-left{display:flex;gap:12px;align-items:center}.event-header-right{display:flex;gap:10px;align-items:center}.event-count{font-weight:700}.toggle-icon{transition:transform .15s ease}.toggle-icon.open{transform:rotate(180deg)}.event-content{padding:16px}.invitation-card{border:1px solid var(--border);border-radius:14px;padding:12px;display:grid;grid-template-columns:1fr auto;gap:12px;background:#ffffff05}.invitation-main{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center}.invitation-body{display:flex;flex-direction:column;gap:6px}.invite-name{margin:0;font-weight:700}.invite-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:capitalize}.status-badge.emerald{background:#10b98126;color:#34d399}.status-badge.amber{background:#f59e0b26;color:#fbbf24}.status-badge.red{background:#ef444426;color:#f87171}.status-badge.gray{background:#94a3b833;color:#cbd5e1}.empty-state{display:grid;gap:10px;place-items:center;text-align:center;padding:24px}.tile-icon{width:36px;height:36px;border-radius:10px;background:#ffffff0f;display:grid;place-items:center}.hero-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;padding:18px;border-radius:20px;background:linear-gradient(135deg,#6366f133,#8b5cf626);border:1px solid var(--border)}.hero-card h2{margin:8px 0}.hero-metric{padding:14px;border:1px solid var(--border);border-radius:14px;background:#ffffff0a}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#22d3ee26;color:#a5f3fc;font-weight:700;font-size:12px}.chip{text-transform:capitalize}.mini-metrics{display:flex;gap:12px;color:var(--muted);font-size:13px}.list-row .pill.small{background:#ffffff0f;color:#e7ecf5}.avatar-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#22d3ee);display:grid;place-items:center;color:#0b0f16;font-weight:700}.button-column{display:grid;gap:6px}.upload-dropzone{margin-top:12px;border:1px dashed var(--border);border-radius:14px;padding:24px;text-align:center;color:var(--muted);background:#ffffff05;display:grid;gap:6px;place-items:center}.note-card{border:1px solid var(--border);border-radius:12px;padding:12px 14px;background:#ffffff08;display:flex;gap:10px;align-items:flex-start}.note-card.subtle{background:#ffffff05}.note-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:#8b5cf61a;color:#d6c4ff}.note-icon.success{background:#10b9811a;color:#6ee7b7}.note-icon.warning{background:#f59e0b1a;color:#fcd34d}.note-icon.error{background:#ef44441a;color:#fca5a5}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;border:1px solid var(--border);background:#ffffff08}.alert.error{background:#ef44441a;border-color:#ef44444d;color:#fca5a5}.alert.warning{background:#f59e0b1a;border-color:#f59e0b4d;color:#fcd34d}.alert.success{background:#10b9811a;border-color:#10b9814d;color:#6ee7b7}.alert.info{background:#3b82f61a;border-color:#3b82f64d;color:#bfdbfe}.note-icon.warning{background:#f472b61f;color:#f472b6}.share-card.token{border:1px solid rgba(16,185,129,.25)}.share-card.email{border:1px solid rgba(59,130,246,.25)}.share-card.approval{border:1px solid rgba(245,158,11,.25)}.mini-list{list-style:none;padding:0;margin:6px 0 0;color:var(--muted);display:grid;gap:4px;font-size:14px}.requirements{border:1px solid var(--border);border-radius:12px;padding:12px;background:#ffffff05;display:grid;gap:8px}.requirement{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px}.requirement.valid{color:#a5f3c5}.builder-shell{display:flex;flex-direction:column;gap:18px}.builder-topbar{display:flex;justify-content:space-between;align-items:center;gap:12px}.builder-actions{display:flex;align-items:center;gap:10px}.banner-card{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px;background:linear-gradient(135deg,#8b5cf614,#22d3ee0f);border:1px dashed rgba(139,92,246,.35)}.banner-right{display:flex;gap:8px}.builder-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}.builder-left{display:flex;flex-direction:column;gap:14px}.builder-card{padding:16px}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:12px}.template-card{width:100%;text-align:left;border:1px solid var(--border);background:linear-gradient(145deg,#ffffff05,#ffffff03);border-radius:14px;padding:12px;color:inherit;cursor:pointer}.template-card.active{border-color:#8b5cf680;box-shadow:0 18px 45px #8b5cf633}.template-top{display:flex;align-items:center;gap:10px}.template-icon{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#0b0f16}.template-meta h4{margin:0}.template-badges{display:flex;gap:8px;margin-top:8px}.pill.subtle{background:#ffffff0f;color:inherit;border:1px solid var(--border)}.grid-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.color-input{padding:6px 10px;height:44px}.stack-md{gap:12px;display:flex;flex-direction:column}.stack-sm{gap:10px;display:flex;flex-direction:column}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border)}.recipient-actions{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px}.toggle-title{display:inline-flex;align-items:center;gap:8px;font-weight:600}.switch{position:relative;display:inline-block;width:46px;height:24px}.switch input{display:none}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border);transition:.2s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}.switch input:checked+.slider{background-color:var(--accent)}.switch input:checked+.slider:before{transform:translate(20px)}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.action-tile{border:1px solid var(--border);border-radius:12px;background:#ffffff05;padding:14px;text-align:left;color:inherit}.action-label{font-weight:600}.placeholder{height:180px;border:1px dashed var(--border);border-radius:12px;display:grid;place-items:center;color:var(--muted)}.table-card{width:100%;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card)}.table-head,.table-row{display:grid;align-items:center;gap:10px;padding:12px 14px}.table-head{background:#ffffff05;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}.table-row{border-top:1px solid var(--border)}.row-actions{display:inline-flex;gap:10px;align-items:center;justify-content:flex-end}.table-cols-4{grid-template-columns:1.2fr 1fr 1fr 1fr}.table-cols-5{grid-template-columns:1fr 1fr 1fr 1fr 1fr}.table-cols-6{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr}.table-cols-7{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr 1fr}.table-cols-8{grid-template-columns:50px 1.5fr 1fr 1fr 100px 80px 120px 200px}.table-loading,.table-empty{padding:3rem;text-align:center;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{animation:spin 1s linear infinite}.table-responsive{overflow-x:auto}@media(max-width:1200px){.table-cols-8{grid-template-columns:40px 200px 150px 120px 100px 80px 100px 180px}}@media(max-width:992px){.table-cols-8{grid-template-columns:40px 180px 120px 100px 90px 70px 90px 150px;font-size:.875rem}.table-cols-6{grid-template-columns:180px 120px 100px 80px 100px 150px;font-size:.875rem}}@media(max-width:768px){.table-head,.table-row{padding:10px 12px;font-size:.8125rem}.table-cols-8{grid-template-columns:35px 150px 100px 90px 80px 60px 80px 120px}.table-cols-6{grid-template-columns:150px 100px 80px 70px 90px 120px}.row-actions{flex-direction:column;gap:4px}.row-actions button{font-size:.75rem;padding:4px 8px}}.pagination{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:var(--card);border:1px solid var(--border);border-radius:12px}.pagination-info{color:var(--muted);font-size:.875rem}.status-badge.blue{background:#3b82f629;color:#bfdbfe}.card.stat-card.admin{min-height:132px}.portal-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--surface)}.portal-card{width:min(420px,100%);background:var(--card);border:1px solid var(--border);border-radius:18px;padding:28px;display:grid;gap:12px;box-shadow:var(--shadow);text-align:center}.portal-logo{width:96px;height:96px;margin:0 auto 8px;border-radius:24px;box-shadow:0 12px 32px #00000040}.spin{animation:spin .9s linear infinite}.unauthorized-page{min-height:100vh;display:grid;place-items:center;padding:32px;background:radial-gradient(circle at 20% 20%,rgba(139,92,246,.18),transparent 30%),radial-gradient(circle at 80% 0%,rgba(34,211,238,.14),transparent 26%),var(--bg)}.unauthorized-card{width:min(820px,100%);background:linear-gradient(180deg,#ffffff05,#fff0);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;gap:18px}.unauthorized-card .brand-row{display:flex;align-items:center;gap:14px}.unauthorized-card .text-group .eyebrow{text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:12px;color:var(--muted);margin:0 0 6px}.unauthorized-card h1{margin:0;font-size:28px;letter-spacing:-.02em}.unauthorized-card p{margin:0}.unauthorized-card .muted{color:var(--muted)}.unauthorized-card .actions{display:flex;flex-direction:column;gap:10px}.unauthorized-card .action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.unauthorized-card .actions.gap{flex-direction:row;flex-wrap:wrap;gap:10px}.primary-button,.secondary-button{border-radius:12px}.secondary-button.danger{border-color:#ef4444;color:#fca5a5}.is-loading{position:relative;pointer-events:none;opacity:.9}.is-loading .spin{margin-right:8px}.primary-button.is-loading,.secondary-button.is-loading{color:transparent}.primary-button.is-loading:after,.secondary-button.is-loading:after{content:"";position:absolute;inset:50% auto auto 50%;width:18px;height:18px;margin:-9px 0 0 -9px;border-radius:50%;border:2px solid rgba(255,255,255,.6);border-top-color:transparent;animation:spin .8s linear infinite}.w-full{width:100%}.inline{display:inline-flex;align-items:center;gap:6px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.builder-preview{position:sticky;top:16px;height:fit-content;display:flex;flex-direction:column;gap:12px}.preview-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.preview-actions{display:flex;gap:8px}.preview-card-shell{border:1px solid var(--border);border-radius:16px;overflow:hidden;background:var(--card)}.preview-hero{padding:18px;color:#0b0f16;display:flex;flex-direction:column;gap:10px}.preview-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px}.preview-row{display:flex;align-items:center;gap:8px}.preview-footer{margin-top:6px;padding-top:10px;border-top:1px dashed var(--border)}.flip{transform:scaleX(-1)}@media(max-width:1100px){.builder-grid{grid-template-columns:1fr}.builder-preview{position:static}}@media(max-width:960px){.auth-grid{grid-template-columns:1fr}.hero-pane{display:none}.form-card{box-shadow:none;border:1px solid rgba(255,255,255,.04)}}@keyframes floatIn{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--card);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-card.large{max-width:800px}.modal-card.modal-wide{max-width:900px}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-body{padding:1.5rem;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;-webkit-overflow-scrolling:touch}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:.75rem}.modal-tabs{display:flex;border-bottom:1px solid var(--border);background:#8b5cf605}.modal-tab{flex:1;padding:1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.modal-tab:hover{color:var(--text);background:#8b5cf60d}.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:#8b5cf614}.checkbox-card{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;background:var(--card)}.checkbox-card:hover{border-color:var(--accent);background:#8b5cf60d}.checkbox-card input[type=checkbox]{margin-top:2px;cursor:pointer}.checkbox-card input[type=checkbox]:checked~.checkbox-content{color:var(--accent)}.checkbox-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.field-group{padding:1.5rem;border:1px solid var(--border);border-radius:12px;background:#8b5cf605}.field-group-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:1rem}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:var(--muted);pointer-events:none}.form-input.with-icon{padding-left:40px}.input-action{position:absolute;right:8px;padding:6px;background:transparent;border:none;color:var(--muted);cursor:pointer;border-radius:4px;transition:all .2s ease}.input-action:hover{color:var(--text);background:#8b5cf61a}.field-error{margin-top:.5rem;font-size:.875rem;color:#ef4444}.field-hint{margin-top:.5rem;font-size:.875rem;color:var(--muted)}.image-upload-dropzone{border:2px dashed var(--border);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#8b5cf608}.image-upload-dropzone:hover{border-color:var(--accent);background:#8b5cf614}.image-upload-dropzone.active{border-color:var(--accent);background:#8b5cf61f;border-style:solid}.image-upload-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.image-upload-content svg{color:var(--accent);opacity:.6}.image-upload-content p{margin:0;font-weight:500}.image-upload-preview{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#8b5cf608}.image-upload-preview img{width:100%;height:auto;max-height:300px;object-fit:cover;display:block}.image-upload-remove{position:absolute;top:.75rem;right:.75rem;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease}.image-upload-remove:hover{background:#dc2626e6;border-color:#dc26264d}.field-error{margin-top:.5rem;color:#ef4444;font-size:.875rem}.field input[type=text],.field input[type=email],.field input[type=date],.field input[type=number],.field textarea,.field select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:#ffffff05;color:var(--text);font-family:inherit;font-size:.9375rem;transition:all .2s ease}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);background:#8b5cf60d}.field input:disabled,.field textarea:disabled,.field select:disabled{opacity:.6;cursor:not-allowed}.field textarea{resize:vertical;min-height:100px}.field label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.field label svg{color:var(--accent)}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease}.checkbox-label:hover{background:#8b5cf60d;border-color:var(--accent)}.checkbox-label input[type=checkbox]{margin-top:.25rem;cursor:pointer}.checkbox-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.checkbox-content svg{color:var(--accent);margin-top:.125rem;flex-shrink:0}.checkbox-content strong{display:block;margin-bottom:.25rem}.required{color:#ef4444}.filters-card{padding:0!important}.filters-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);gap:1rem}.filters-title{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1rem}.clear-filters-button{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;background:var(--background);border:1px solid var(--border);border-radius:6px;font-size:.8125rem;color:var(--muted);cursor:pointer;transition:all .2s ease}.clear-filters-button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.view-toggle{display:flex;gap:.25rem;background:var(--background);border:1px solid var(--border);border-radius:8px;padding:.25rem}.view-toggle-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--muted);border-radius:6px;cursor:pointer;transition:all .2s ease}.view-toggle-button:hover{background:#8b5cf61a;color:var(--accent)}.view-toggle-button.active{background:var(--accent);color:#fff}.filters-content{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.filter-section{display:flex;flex-direction:column;gap:.75rem}.filter-section-full{grid-column:1 / -1}.filter-label{font-size:.8125rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.05em}.chip-group{display:flex;flex-wrap:wrap;gap:.5rem}.chip-filter{padding:.5rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:8px;font-size:.875rem;font-weight:500;color:var(--text);cursor:pointer;transition:all .2s ease;white-space:nowrap}.chip-filter:hover{background:#8b5cf61a;border-color:var(--accent);color:var(--accent)}.chip-filter.active{background:var(--accent);border-color:var(--accent);color:#fff}.search-input{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--background);border:1px solid var(--border);border-radius:8px;transition:all .2s ease}.search-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #8b5cf61a}.search-input svg{color:var(--muted);flex-shrink:0}.search-input-field{flex:1;border:none;background:transparent;color:var(--text);font-size:.9375rem;outline:none}.search-input-field::placeholder{color:var(--muted)}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.events-list{display:flex;flex-direction:column;gap:1rem}.event-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s ease;cursor:pointer;display:flex;flex-direction:column}.event-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.event-card.list{flex-direction:row;align-items:center}.event-card-image{position:relative;width:100%;height:180px;overflow:hidden;background:var(--background)}.event-card.list .event-card-image{width:200px;height:140px;flex-shrink:0}.event-card-image img{width:100%;height:100%;object-fit:cover}.event-card-badges{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.5rem}.event-card.list .event-card-badges{position:static}.event-card-content{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.75rem}.event-card.list .event-card-content{padding:1rem 1.25rem}.event-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.event-card-title{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.event-card-title svg{color:var(--accent);flex-shrink:0}.event-card-title h4{margin:0;font-size:1.0625rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-card-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.875rem;color:var(--muted)}.event-meta-item{display:flex;align-items:center;gap:.5rem}.event-card-description{margin:0;font-size:.875rem;color:var(--muted);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.event-card-actions{display:flex;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--border);background:var(--background)}.event-card.list .event-card-actions{flex-direction:column;border-top:none;border-left:1px solid var(--border);padding:1rem .75rem;background:transparent}.icon-button-secondary,.icon-button-danger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);background:var(--card);border-radius:8px;cursor:pointer;transition:all .2s ease;color:var(--text)}.icon-button-secondary:hover{background:#8b5cf61a;border-color:var(--accent);color:var(--accent)}.icon-button-danger:hover{background:#dc26261a;border-color:#dc2626;color:#dc2626}.modal-large{max-width:800px}.event-detail-cover{width:100%;height:300px;border-radius:12px;overflow:hidden;background:var(--background)}.event-detail-cover img{width:100%;height:100%;object-fit:cover}.event-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.event-detail-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--text)}.badge-group{display:flex;gap:.5rem;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;padding:1.5rem;background:var(--background);border:1px solid var(--border);border-radius:12px}.detail-item{display:flex;align-items:flex-start;gap:.75rem}.detail-item svg{color:var(--accent);flex-shrink:0;margin-top:.25rem}.detail-item p{margin:0 0 .25rem}.detail-item strong{font-size:1rem;color:var(--text)}.detail-section{display:flex;flex-direction:column;gap:1rem}.detail-section h4{margin:0;font-size:1.125rem;font-weight:600;color:var(--text)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.gallery-mini-card{background:var(--background);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .2s ease}.gallery-mini-card:hover{border-color:var(--accent);transform:translateY(-2px)}.gallery-mini-card img{width:100%;height:100px;object-fit:cover}.gallery-mini-info{padding:.75rem}.gallery-mini-info strong{display:block;font-size:.875rem;margin-bottom:.25rem;color:var(--text)}.stats-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-mini-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border:1px solid var(--border);border-radius:8px}.stat-mini-card svg{color:var(--accent)}.stat-mini-card strong{display:block;font-size:.9375rem;margin-bottom:.25rem;color:var(--text)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;text-align:center;grid-column:1 / -1}.empty-icon{color:var(--muted);opacity:.5}.empty-state h3{margin:0;font-size:1.25rem;color:var(--text)}@media(max-width:768px){.filters-content,.events-grid{grid-template-columns:1fr}.event-card.list{flex-direction:column}.event-card.list .event-card-image{width:100%;height:180px}.event-card.list .event-card-actions{flex-direction:row;border-left:none;border-top:1px solid var(--border);padding:.75rem 1.25rem}.detail-grid{grid-template-columns:1fr}.modal-large{max-width:100%}.modal-overlay{padding:1rem}.modal-card{max-height:85vh}.modal-header,.modal-body,.modal-footer{padding:1.25rem}.stat-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.filters-header{flex-direction:column;align-items:stretch}.view-toggle{width:100%}.view-toggle-button{flex:1}.stat-grid{grid-template-columns:1fr}.modal-overlay{padding:.5rem}.modal-card{max-height:95vh;border-radius:12px}.modal-header,.modal-body,.modal-footer{padding:1rem}.modal-footer{flex-direction:column-reverse;gap:.5rem}.modal-footer button{width:100%}.hero-card{flex-direction:column}.button-row{flex-wrap:wrap}}@media(prefers-color-scheme:dark){.event-card:hover{box-shadow:0 4px 12px #0000004d}.modal-overlay{background:#000000d9}}@media(prefers-color-scheme:light){.event-card:hover{box-shadow:0 4px 12px #00000014}.modal-overlay{background:#0009}}:root[data-theme=light] .secondary-button{background:#fff;color:#0f172a;border-color:#e2e8f0}:root[data-theme=light] .secondary-button:hover{background:#f1f5f9;border-color:#7c3aed;color:#7c3aed}:root[data-theme=light] .text-button{color:#0ea5e9}:root[data-theme=light] .text-button:hover{color:#0284c7}:root[data-theme=light] .primary-button{color:#fff;box-shadow:0 8px 20px #7c3aed40}:root[data-theme=light] .pill.small.emerald{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}:root[data-theme=light] .pill.small.amber{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}:root[data-theme=light] .pill.small.blue{background:#3b82f61a;color:#2563eb;border:1px solid rgba(59,130,246,.2)}:root[data-theme=light] .pill.small.pink{background:#ec48991a;color:#db2777;border:1px solid rgba(236,72,153,.2)}:root[data-theme=light] .pill.small.purple{background:#6366f11a;color:#6366f1;border:1px solid rgba(99,102,241,.2)}:root[data-theme=light] .icon-button-secondary{background:#fff;color:#475569;border-color:#e2e8f0}:root[data-theme=light] .icon-button-secondary:hover{background:#f8f4ff;border-color:#7c3aed;color:#7c3aed}:root[data-theme=light] .icon-button-danger{background:#fff;color:#475569}:root[data-theme=light] .icon-button-danger:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}:root[data-theme=light] .icon-button{background:#fff;color:#475569;border-color:#e2e8f0}:root[data-theme=light] .icon-button:hover{background:#f1f5f9;border-color:#7c3aed;color:#7c3aed}:root[data-theme=light] .chip-filter{background:#fff;color:#475569;border-color:#e2e8f0}:root[data-theme=light] .chip-filter:hover{background:#f8f4ff;border-color:#7c3aed;color:#7c3aed}:root[data-theme=light] .chip-filter.active{background:#7c3aed;border-color:#7c3aed;color:#fff}:root[data-theme=light] .clear-filters-button{background:#fff;color:#64748b;border-color:#e2e8f0}:root[data-theme=light] .clear-filters-button:hover{background:#7c3aed;color:#fff;border-color:#7c3aed}:root[data-theme=light] .view-toggle{background:#f8fafc;border-color:#e2e8f0}:root[data-theme=light] .view-toggle-button{color:#64748b}:root[data-theme=light] .view-toggle-button:hover{background:#7c3aed1a;color:#7c3aed}:root[data-theme=light] .view-toggle-button.active{background:#7c3aed;color:#fff}:root[data-theme=light] .search-input{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .search-input:focus-within{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}:root[data-theme=light] .search-input svg{color:#94a3b8}:root[data-theme=light] .search-input-field{color:#0f172a}:root[data-theme=light] .search-input-field::placeholder{color:#94a3b8}:root[data-theme=light] .event-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .event-card:hover{border-color:#7c3aed;box-shadow:0 4px 12px #0f172a14}:root[data-theme=light] .event-card-image{background:#f8fafc}:root[data-theme=light] .event-card-title h4{color:#0f172a}:root[data-theme=light] .event-card-meta{color:#64748b}:root[data-theme=light] .event-card-description{color:#475569}:root[data-theme=light] .event-card-actions{background:#f8fafc;border-color:#e2e8f0}:root[data-theme=light] .modal-overlay{background:#0006}:root[data-theme=light] .modal-card{background:#fff;border-color:#e2e8f0;box-shadow:0 20px 60px #0f172a33}:root[data-theme=light] .modal-header{border-color:#e2e8f0}:root[data-theme=light] .modal-header h2{color:#0f172a}:root[data-theme=light] .modal-footer{border-color:#e2e8f0}:root[data-theme=light] .event-detail-cover{background:#f8fafc}:root[data-theme=light] .event-detail-header h3{color:#0f172a}:root[data-theme=light] .detail-grid{background:#f8fafc;border-color:#e2e8f0}:root[data-theme=light] .detail-item strong{color:#0f172a}:root[data-theme=light] .detail-section h4{color:#0f172a}:root[data-theme=light] .gallery-mini-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .gallery-mini-card:hover{border-color:#7c3aed}:root[data-theme=light] .gallery-mini-info strong{color:#0f172a}:root[data-theme=light] .stat-mini-card{background:#f8fafc;border-color:#e2e8f0}:root[data-theme=light] .stat-mini-card strong{color:#0f172a}:root[data-theme=light] .loading-state{color:#475569}:root[data-theme=light] .spinner{border-color:#e2e8f0;border-top-color:#7c3aed}:root[data-theme=light] .empty-state h3{color:#0f172a}:root[data-theme=light] .empty-icon{color:#94a3b8}:root[data-theme=light] .stat-card h3{color:#0f172a}:root[data-theme=light] .stat-change{color:#64748b}:root[data-theme=light] .hero-card h3{color:#0f172a}:root[data-theme=light] .badge{background:#7c3aed1a;color:#7c3aed;border:1px solid rgba(124,58,237,.2)}:root[data-theme=light] .mini-metrics span{color:#64748b}:root[data-theme=light] .pagination{color:#475569}:root[data-theme=light] .filters-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .filters-header{border-color:#e2e8f0}:root[data-theme=light] .filters-title{color:#0f172a}:root[data-theme=light] .filter-label{color:#475569}:root[data-theme=light] .card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .card-title{color:#0f172a}:root[data-theme=light] .card-head{border-color:#e2e8f0}:root[data-theme=light] .form-input,:root[data-theme=light] .form-select,:root[data-theme=light] .form-textarea{background:#fff;border-color:#e2e8f0;color:#0f172a}:root[data-theme=light] .form-input:focus,:root[data-theme=light] .form-select:focus,:root[data-theme=light] .form-textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}:root[data-theme=light] .image-upload-dropzone{border-color:#e2e8f0;background:#7c3aed08}:root[data-theme=light] .image-upload-dropzone:hover{border-color:#7c3aed;background:#7c3aed14}:root[data-theme=light] .image-upload-dropzone.active{border-color:#7c3aed;background:#7c3aed1f}:root[data-theme=light] .image-upload-content p{color:#0f172a}:root[data-theme=light] .image-upload-preview{border-color:#e2e8f0;background:#7c3aed08}:root[data-theme=light] .checkbox-label{border-color:#e2e8f0;background:#fff}:root[data-theme=light] .checkbox-label:hover{background:#7c3aed0d;border-color:#7c3aed}:root[data-theme=light] .checkbox-content strong{color:#0f172a}:root[data-theme=light] label{color:#475569}:root[data-theme=light] .muted{color:#64748b}:root[data-theme=light] .small{color:#64748b}:root[data-theme=light] .note-card{border-color:#e2e8f0;background:#f8fafc}:root[data-theme=light] .note-card.warning{background:#fef3c7;border-color:#fbbf24;color:#92400e}:root[data-theme=light] .note-card.error{background:#fee2e2;border-color:#ef4444;color:#991b1b}:root[data-theme=light] .alert{background:#f8fafc;border-color:#e2e8f0;color:#0f172a}:root[data-theme=light] .alert.error{background:#fee2e2;border-color:#ef4444;color:#991b1b}:root[data-theme=light] .alert.warning{background:#fef3c7;border-color:#fbbf24;color:#92400e}:root[data-theme=light] .alert.success{background:#d1fae5;border-color:#10b981;color:#065f46}:root[data-theme=light] .alert.info{background:#dbeafe;border-color:#3b82f6;color:#1e40af}:root[data-theme=light] .stack-lg>*,:root[data-theme=light] .stack-md>*{color:inherit}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.photos-list{display:flex;flex-direction:column;gap:1rem}.photo-card{position:relative;cursor:pointer;transition:transform .2s,box-shadow .2s;border-radius:.5rem;overflow:hidden;background:var(--bg-card)}.photo-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.photo-card.grid{aspect-ratio:1}.photo-card.list{display:flex;flex-direction:row;aspect-ratio:auto}.photo-card-image{position:relative;width:100%;height:100%;overflow:hidden;background:var(--bg-app)}.photo-card.list .photo-card-image{width:200px;flex-shrink:0}.photo-card-image img{width:100%;height:100%;object-fit:cover}.photo-card-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;gap:.5rem;opacity:0;transition:opacity .2s}.photo-card:hover .photo-card-overlay{opacity:1}.photo-card-content{padding:1rem;flex:1}.photo-card-content h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.photo-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.upload-zone{border:2px dashed var(--border);border-radius:.75rem;padding:3rem 2rem;text-align:center;transition:all .2s;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.upload-zone:hover,.upload-zone.drag-active{border-color:var(--primary);background:#7c3aed0d}.upload-zone.has-files{padding:1.5rem;min-height:auto}.upload-zone-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{color:var(--text-muted);transition:color .2s}.upload-zone:hover .upload-icon,.upload-zone.drag-active .upload-icon{color:var(--primary)}.upload-zone h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.upload-zone-files{width:100%}.upload-zone-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.upload-zone-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.photo-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.photo-preview-item{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;border:2px solid var(--border);transition:border-color .2s}.photo-preview-item.uploading{border-color:var(--primary)}.photo-preview-item.success{border-color:#10b981}.photo-preview-item.error{border-color:#ef4444}.photo-preview-item img{width:100%;height:100%;object-fit:cover}.desktop-view{display:block}.mobile-view{display:none}@media(max-width:768px){.desktop-view{display:none}.mobile-view{display:block}}.photo-preview-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .2s}.photo-preview-item:hover .photo-preview-overlay{opacity:1}.photo-preview-item.uploading .photo-preview-overlay,.photo-preview-item.success .photo-preview-overlay,.photo-preview-item.error .photo-preview-overlay{opacity:1;background:#0009}.photo-preview-name{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);font-size:.75rem;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.success-icon{width:40px;height:40px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center}.error-icon{width:40px;height:40px;border-radius:50%;background:#ef4444;color:#fff;display:flex;align-items:center;justify-content:center}.photo-details-image{width:100%;max-height:500px;border-radius:.5rem;overflow:hidden;margin-bottom:1.5rem;background:var(--bg-app)}.photo-details-image img{width:100%;height:100%;object-fit:contain}.form-value{padding:.75rem 1rem;background:var(--bg-app);border-radius:.5rem;color:var(--text-primary);min-height:2.75rem;display:flex;align-items:center}:root[data-theme=light] .photo-card{background:#fff;border:1px solid #e2e8f0}:root[data-theme=light] .photo-card:hover{box-shadow:0 4px 12px #0000001a}:root[data-theme=light] .photo-card-content h4{color:#0f172a}:root[data-theme=light] .upload-zone{border-color:#cbd5e1;background:#f8fafc}:root[data-theme=light] .upload-zone:hover,:root[data-theme=light] .upload-zone.drag-active{border-color:#7c3aed;background:#7c3aed0d}:root[data-theme=light] .upload-zone h3{color:#0f172a}:root[data-theme=light] .upload-zone-header h4{color:#0f172a}:root[data-theme=light] .photo-preview-item{border-color:#e2e8f0}:root[data-theme=light] .photo-details-image{background:#f8fafc;border:1px solid #e2e8f0}:root[data-theme=light] .form-value{background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a}.modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-content{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);width:100%;max-width:600px;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;margin:auto}.modal-content.modal-large{max-width:900px}.modal-content.modal-xl{max-width:1200px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text)}.modal-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-header button:hover{background:var(--border);color:var(--text)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:var(--card)}.modal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--muted)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border);flex-shrink:0}.modal-preview-container{border:1px solid var(--border);border-radius:8px;padding:1.5rem;background:var(--bg);max-height:60vh;overflow-y:auto}.modal-preview-container::-webkit-scrollbar{width:8px}.modal-preview-container::-webkit-scrollbar-track{background:var(--card)}.modal-preview-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-preview-container::-webkit-scrollbar-thumb:hover{background:var(--muted)}:root[data-theme=light] .modal-overlay{background:#0f172a99}:root[data-theme=light] .modal-content{background:#fff;border-color:#e2e8f0;box-shadow:0 20px 50px #0f172a40}:root[data-theme=light] .modal-header h3{color:#0f172a}:root[data-theme=light] .modal-header button{color:#64748b}:root[data-theme=light] .modal-header button:hover{background:#f1f5f9;color:#0f172a}:root[data-theme=light] .modal-preview-container{background:#f8fafc;border-color:#e2e8f0}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:var(--card)}.table-responsive::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.table-responsive::-webkit-scrollbar-thumb:hover{background:var(--muted)}@media(max-width:1024px){.modal-content{max-width:95vw}.filter-grid{grid-template-columns:1fr;gap:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}}@media(max-width:768px){.modal-overlay{padding:.5rem}.modal-content{max-height:calc(100vh - 1rem);border-radius:12px}.modal-header{padding:1rem}.modal-header h3{font-size:1.1rem}.modal-body{padding:1rem}.modal-footer{padding:1rem;flex-wrap:wrap}.modal-footer button{flex:1;min-width:120px}.modal-preview-container{max-height:50vh;padding:1rem}.hero-card{grid-template-columns:1fr;gap:1.5rem}.hero-metric{text-align:left}.table-row{font-size:.875rem}.table-head{font-size:.75rem}.table-cols-8>div:nth-child(3),.table-cols-8>div:nth-child(4),.table-cols-8>div:nth-child(6){display:none}.table-cols-6>div:nth-child(2),.table-cols-6>div:nth-child(4){display:none}.button-row{flex-direction:column;align-items:stretch}.button-row button{width:100%}.filter-card form{grid-template-columns:1fr}}@media(max-width:480px){.modal-header h3{font-size:1rem}.modal-body,.modal-footer,.modal-preview-container{padding:.75rem}.stats-grid{grid-template-columns:1fr}.pagination{flex-direction:column;gap:.5rem}.pagination-info{order:-1;font-size:.875rem}}.stack-lg{display:flex;flex-direction:column;gap:1.5rem}.hero-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2rem;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start}.hero-card .badge{display:inline-flex;padding:.25rem .75rem;background:var(--accent);color:#fff;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.hero-card h2{margin:.5rem 0;font-size:1.75rem;font-weight:700}.hero-card p.muted{color:var(--muted);margin:.5rem 0 1rem}.hero-metric{text-align:right}.hero-metric .pill{display:inline-flex;padding:.375rem .875rem;background:var(--border);color:var(--text);border-radius:20px;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.hero-metric h3{margin:.5rem 0;font-size:2.5rem;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.stat-icon{color:var(--accent);flex-shrink:0}.stat-value{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:var(--muted);font-size:.875rem}.filter-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.card-head{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;padding:1.5rem}:root[data-theme=light] .hero-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .hero-card h2{color:#0f172a}:root[data-theme=light] .hero-metric .pill{background:#f1f5f9;color:#0f172a}:root[data-theme=light] .stat-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .filter-card{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .card-head{border-bottom-color:#e2e8f0}
