:root{--navy-deep: #070b14;--navy-900: #0a0f1c;--navy-800: #0c1424;--brand-900: #0a2a66;--brand-700: #134a9e;--brand-500: #1e63d0;--brand-400: #3b82f6;--accent: #1e63d0;--accent-soft: rgba(30, 99, 208, .16);--surface: rgba(18, 26, 44, .72);--surface-solid: #111a2c;--surface-2: rgba(255, 255, 255, .035);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--text: #eef2f8;--text-dim: #9fb0c3;--text-faint: #6b7a90;--danger: #ff6b6b;--danger-bg: rgba(255, 107, 107, .12);--success: #34d399;--warn: #fbbf24;--radius: 16px;--radius-sm: 11px;--shadow: 0 24px 60px rgba(0, 0, 0, .45);--shadow-sm: 0 8px 24px rgba(0, 0, 0, .3);--font: system-ui, -apple-system, "Segoe UI", Roboto, Inter, Arial, sans-serif}*{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--navy-deep);-webkit-font-smoothing:antialiased;background-image:radial-gradient(1100px 560px at 12% -8%,rgba(30,99,208,.18),transparent 60%),radial-gradient(900px 600px at 100% 0%,rgba(10,42,102,.28),transparent 55%),linear-gradient(170deg,#080d18,#070b14);background-attachment:fixed}a{color:var(--brand-400);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--accent-soft)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:8px}*::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.container{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}.page{flex:1;padding:28px 0 64px;animation:fade .35s ease both}@keyframes fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}.topbar{position:sticky;top:0;z-index:30;background:#080c16b8;backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--border)}.topbar-inner{display:flex;align-items:center;gap:16px;height:64px}.brand{display:flex;align-items:center;gap:11px;font-weight:700;letter-spacing:.2px}.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--brand-500),var(--brand-900));display:grid;place-items:center;color:#fff;font-size:15px;font-weight:800;box-shadow:0 6px 18px #1e63d066}.brand small{display:block;font-weight:500;font-size:11px;color:var(--text-dim);letter-spacing:.4px}.topbar-spacer{flex:1}.user-chip{display:flex;align-items:center;gap:9px;padding:6px 8px 6px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);font-size:13px;color:var(--text-dim)}.user-chip .avatar{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));color:#fff;font-size:12px;font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;font-size:14px;font-weight:600;font-family:inherit;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));box-shadow:0 8px 22px #1e63d057;transition:transform .08s,filter .15s,opacity .15s,background .15s;white-space:nowrap}.btn:hover{filter:brightness(1.07)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed;filter:none}.btn.ghost{background:var(--surface-2);color:var(--text);border-color:var(--border-strong);box-shadow:none}.btn.ghost:hover{background:#ffffff12;filter:none}.btn.danger{background:transparent;color:var(--danger);border-color:#ff6b6b66;box-shadow:none}.btn.danger:hover{background:var(--danger-bg);filter:none}.btn.sm{padding:8px 13px;font-size:13px;border-radius:9px}.btn.block{width:100%}.btn.link{background:none;box-shadow:none;color:var(--brand-400);padding:6px 4px}.btn.link:hover{text-decoration:underline;filter:none}.card{background:var(--surface);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-size:13px;font-weight:600;color:var(--text-dim)}.field .hint{font-size:11.5px;color:var(--text-faint)}.input,.textarea{width:100%;padding:12px 14px;font-size:14.5px;font-family:inherit;color:var(--text);background:#070b1499;border:1px solid var(--border-strong);border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s}.textarea{resize:vertical;min-height:64px;line-height:1.45}.input::placeholder,.textarea::placeholder{color:var(--text-faint)}.input:focus,.textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px var(--accent-soft)}.input.invalid{border-color:var(--danger)}.input-group{display:flex;align-items:stretch}.input-group .input{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.input-group .suffix{display:flex;align-items:center;padding:0 13px;font-size:13px;color:var(--text-dim);background:#ffffff0a;border:1px solid var(--border-strong);border-left:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;white-space:nowrap}.check-row{display:flex;align-items:flex-start;gap:11px;cursor:pointer;font-size:13.5px;color:var(--text)}.check-row input{width:18px;height:18px;margin-top:1px;accent-color:var(--brand-500);flex:0 0 auto;cursor:pointer}.color-field{display:flex;align-items:center;gap:11px}.color-swatch{width:44px;height:40px;border-radius:10px;border:1px solid var(--border-strong);padding:0;cursor:pointer;background:none;overflow:hidden}.color-swatch::-webkit-color-swatch-wrapper{padding:0}.color-swatch::-webkit-color-swatch{border:none;border-radius:8px}.color-hex{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:13px;color:var(--text-dim);text-transform:uppercase}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.upload{border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:14px;display:flex;align-items:center;gap:13px;cursor:pointer;transition:border-color .15s,background .15s;background:#ffffff05}.upload:hover{border-color:var(--brand-500);background:var(--accent-soft)}.upload .thumb{width:52px;height:52px;border-radius:9px;flex:0 0 auto;overflow:hidden;background:#070b1499 center/cover no-repeat;display:grid;place-items:center;color:var(--text-faint);font-size:11px;border:1px solid var(--border)}.upload .thumb img{width:100%;height:100%;object-fit:contain}.upload-meta{flex:1;min-width:0}.upload-meta .t{font-size:13.5px;font-weight:600}.upload-meta .s{font-size:11.5px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-badge{font-size:11px;color:var(--brand-400)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);text-transform:capitalize}.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint)}.badge.active{color:var(--success);border-color:#34d3994d;background:#34d3991a}.badge.active .dot{background:var(--success)}.badge.draft{color:var(--warn);border-color:#fbbf244d;background:#fbbf241a}.badge.draft .dot{background:var(--warn)}.portal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}.portal-card{position:relative;padding:0;overflow:hidden;cursor:pointer;transition:transform .14s,border-color .15s,box-shadow .15s}.portal-card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow)}.portal-card .cover{height:92px;position:relative;background:linear-gradient(135deg,var(--brand-700),var(--navy-900))}.portal-card .cover .logo{position:absolute;left:18px;bottom:-22px;width:52px;height:52px;border-radius:13px;background:var(--surface-solid) center/contain no-repeat;border:1px solid var(--border-strong);box-shadow:var(--shadow-sm);display:grid;place-items:center;font-weight:800;color:#fff;font-size:19px}.portal-card .body{padding:30px 18px 18px}.portal-card .pname{font-size:16px;font-weight:700;margin:0 0 4px}.portal-card .psub{font-size:12.5px;color:var(--brand-400);display:inline-flex;align-items:center;gap:5px}.portal-card .psub:hover{text-decoration:underline}.portal-card .meta-row{display:flex;align-items:center;justify-content:space-between;margin-top:16px}.portal-card .date{font-size:11.5px;color:var(--text-faint)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}.page-head h1{font-size:24px;margin:0 0 4px;letter-spacing:-.3px}.page-head .sub{color:var(--text-dim);font-size:14px;margin:0}.crumb{display:inline-flex;align-items:center;gap:7px;color:var(--text-dim);font-size:13px;margin-bottom:14px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.crumb:hover{color:var(--text)}.editor{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:26px;align-items:start}.editor-form{min-width:0}.editor-preview{position:sticky;top:88px}.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);margin:26px 0 14px}.section-title:first-child{margin-top:0}.preview-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);aspect-ratio:9 / 16;max-height:540px;position:relative}.preview-label{font-size:11.5px;color:var(--text-faint);text-align:center;margin-bottom:10px;letter-spacing:.4px}.pv-bg{position:absolute;inset:0;background-size:cover;background-position:center}.pv-wrap{position:relative;height:100%;display:flex;align-items:center;justify-content:center;padding:22px}.pv-card{width:100%;max-width:260px;background:#141c28b8;backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:22px 18px;text-align:center;box-shadow:0 16px 40px #00000073}.pv-logo{max-width:110px;max-height:44px;margin:0 auto 12px;display:block;object-fit:contain}.pv-logo-fb{font-size:16px;font-weight:800;margin-bottom:12px}.pv-welcome{font-size:13px;font-weight:600;line-height:1.42;margin:0 0 16px}.pv-input{width:100%;padding:10px 12px;font-size:12.5px;text-align:left;color:var(--text-dim);background:#070b148c;border:1px solid rgba(255,255,255,.14);border-radius:9px;margin-bottom:11px}.pv-consent{display:flex;gap:7px;text-align:left;font-size:10.5px;color:var(--text-dim);margin-bottom:12px;line-height:1.35}.pv-consent .box{width:14px;height:14px;border:1px solid rgba(255,255,255,.3);border-radius:4px;flex:0 0 auto}.pv-btn{width:100%;padding:11px;font-size:13px;font-weight:600;color:#fff;border:none;border-radius:9px}.pv-foot{margin-top:13px;font-size:9.5px;color:var(--text-faint)}.funnel{display:flex;flex-direction:column;gap:13px}.funnel-row{display:grid;grid-template-columns:150px 1fr;gap:14px;align-items:center}.funnel-row .flabel{font-size:13px;color:var(--text-dim)}.funnel-row .flabel b{display:block;color:var(--text);font-size:15px;font-weight:700}.fbar-track{height:38px;background:#ffffff0a;border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--border)}.fbar-fill{height:100%;border-radius:10px;min-width:2px;background:linear-gradient(90deg,var(--brand-700),var(--brand-500));display:flex;align-items:center;justify-content:flex-end;padding-right:12px;transition:width .6s cubic-bezier(.2,.8,.2,1);color:#fff;font-size:12.5px;font-weight:700}.fbar-pct{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-dim);font-weight:600}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.stat{padding:16px 18px}.stat .v{font-size:26px;font-weight:800;letter-spacing:-.5px}.stat .k{font-size:12px;color:var(--text-dim);margin-top:2px}.stat .pill{font-size:11px;color:var(--brand-400);margin-top:6px}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{text-align:left;padding:12px 16px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);background:#ffffff06;border-bottom:1px solid var(--border)}tbody td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.045);color:var(--text)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#ffffff05}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace}.tabs{display:flex;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;width:fit-content;margin-bottom:22px}.tab{padding:8px 16px;font-size:13px;font-weight:600;color:var(--text-dim);border-radius:9px;cursor:pointer;border:none;background:none;font-family:inherit;transition:color .15s,background .15s}.tab.active{color:var(--text);background:#1e63d038}.alert{display:flex;gap:10px;padding:12px 14px;border-radius:var(--radius-sm);font-size:13.5px;line-height:1.45;margin-bottom:16px;align-items:flex-start}.alert.error{background:var(--danger-bg);border:1px solid rgba(255,107,107,.3);color:#ffb3b3}.alert.success{background:#34d3991a;border:1px solid rgba(52,211,153,.3);color:#86efc4}.alert.info{background:var(--accent-soft);border:1px solid rgba(30,99,208,.3);color:#a9c8f7}.empty{text-align:center;padding:64px 24px;color:var(--text-dim)}.empty .emoji{font-size:40px;margin-bottom:14px;opacity:.85}.empty h3{color:var(--text);font-size:18px;margin:0 0 6px}.empty p{margin:0 auto 18px;max-width:380px;font-size:14px;line-height:1.5}.spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid rgba(255,255,255,.18);border-top-color:#fff;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle}.spinner.dark{border-color:#1e63d038;border-top-color:var(--brand-500)}.spinner.lg{width:34px;height:34px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;flex-direction:column;align-items:center;gap:14px;padding:72px 0;color:var(--text-dim);font-size:14px}.auth-shell{position:relative;overflow:hidden;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-shell:before,.auth-shell:after{content:"";position:absolute;inset:-20%;z-index:0;pointer-events:none;transition:opacity .8s ease;filter:blur(8px)}.auth-shell:before{opacity:1;background:radial-gradient(40% 50% at 28% 20%,rgba(30,99,208,.34),transparent 70%),radial-gradient(45% 55% at 82% 84%,rgba(10,42,102,.4),transparent 65%)}.auth-shell:after{opacity:0;background:radial-gradient(40% 50% at 28% 20%,rgba(20,184,166,.3),transparent 70%),radial-gradient(45% 55% at 82% 84%,rgba(13,90,80,.42),transparent 65%)}.auth-shell.mode-client:before{opacity:0}.auth-shell.mode-client:after{opacity:1}.auth-card{position:relative;z-index:1;width:100%;max-width:400px;padding:36px 30px;animation:rise .5s cubic-bezier(.2,.8,.2,1) both}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:22px}.auth-brand .mark{width:54px;height:54px;border-radius:15px;font-size:22px;transition:background .7s ease,box-shadow .7s ease}.auth-brand h1{font-size:21px;margin:0;letter-spacing:-.2px}.auth-brand p{font-size:13px;color:var(--text-dim);margin:2px 0 0;transition:color .4s ease}.auth-toggle{display:flex;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;margin-bottom:14px}.auth-toggle button{flex:1;padding:10px;font-size:13.5px;font-weight:600;color:var(--text-dim);background:none;border:none;border-radius:8px;cursor:pointer;font-family:inherit;transition:background .35s ease,color .35s ease}.auth-toggle button.on{color:#fff}.auth-shell:not(.mode-client) .auth-toggle button.on{background:var(--accent)}.auth-shell.mode-client .auth-toggle button.on{background:#14b8a6}.auth-hint{font-size:12.5px;color:var(--text-faint);text-align:center;margin:0 0 18px;line-height:1.45;transition:color .4s ease}.auth-shell .brand-mark,.auth-shell .btn.block,.auth-shell .input{transition:background .7s ease,border-color .4s ease,box-shadow .4s ease,color .4s ease}.auth-shell.mode-client .brand-mark{background:linear-gradient(135deg,#2dd4bf,#0d5a50);box-shadow:0 8px 24px #14b8a652}.auth-shell.mode-client .btn.block{background:linear-gradient(135deg,#14b8a6,#0f766e)}.auth-shell.mode-client .input:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a62e}.modal-overlay{position:fixed;inset:0;z-index:80;background:#04080eb3;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .2s ease both}.modal{background:var(--surface-solid);border:1px solid var(--border-strong);border-radius:var(--radius);padding:26px;max-width:420px;width:100%;box-shadow:var(--shadow);animation:rise .25s cubic-bezier(.2,.8,.2,1) both}.modal h3{margin:0 0 8px;font-size:18px}.modal p{margin:0 0 22px;color:var(--text-dim);font-size:14px;line-height:1.5}.modal-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width: 920px){.editor{grid-template-columns:1fr}.editor-preview{position:static;max-width:360px;margin:0 auto;width:100%}}@media (max-width: 600px){.container{padding:0 16px}.grid-2{grid-template-columns:1fr}.funnel-row{grid-template-columns:110px 1fr}.page-head h1{font-size:21px}}.attrib{margin-top:8px;font-size:12.5px;color:var(--text-faint);display:flex;flex-wrap:wrap;gap:4px 10px;align-items:center}.attrib b{color:var(--text-dim);font-weight:600}.role-chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;background:var(--accent-soft);color:var(--brand-400);font-weight:600;font-size:11.5px}.card-attrib{margin-top:6px;font-size:11.5px;color:var(--text-faint)}select.input{appearance:none;color-scheme:dark;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),linear-gradient(135deg,var(--text-dim) 50%,transparent 50%);background-position:calc(100% - 16px) center,calc(100% - 11px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:30px}.input.sm{padding:6px 26px 6px 10px;font-size:13px;border-radius:8px}.export-bar{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;padding:14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);margin-bottom:16px}.export-bar .field{min-width:150px}.export-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto}.member-form{border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;background:var(--surface-2);margin-bottom:18px}.member-grid{display:grid;grid-template-columns:1.4fr 1.2fr 1fr auto;gap:12px;align-items:end}@media (max-width: 720px){.member-grid{grid-template-columns:1fr}}.role-help{margin:10px 0 0;font-size:12.5px;color:var(--text-faint)}.seg{display:inline-flex;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}.seg .pill{padding:7px 14px;font-size:13px;font-weight:600;color:var(--text-dim);border:none;background:none;border-radius:7px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.seg .pill.on{background:var(--accent);color:#fff}.btn.ghost.sm.danger{color:var(--danger);border-color:#ff6b6b59}.btn.ghost.sm.danger:hover{background:var(--danger-bg)}.activity-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.activity-list li{display:flex;gap:12px;padding:12px 4px;border-bottom:1px solid var(--border);align-items:flex-start}.activity-list li:last-child{border-bottom:none}.activity-list .ai{font-size:16px;line-height:1.4;width:24px;text-align:center;flex:none}.activity-list .at{font-size:13.5px;color:var(--text)}.activity-list .am{font-size:12px;color:var(--text-faint);margin-top:2px}
