 :root { --bg: #070B10; --bg-1: #0C1219; --bg-2: #111A25; --surface: rgba(255,255,255,.042); --surface-2: rgba(255,255,255,.072); --border: rgba(255,255,255,.075); --border-2: rgba(255,255,255,.13); --text: #EDF2FA; --muted: rgba(237,242,250,.56); --muted-2: rgba(237,242,250,.32); --accent: #4F7FFF; --accent-hi: #7BA4FF; --accent-bg: rgba(79,127,255,.11); --accent-border: rgba(79,127,255,.24); --shadow-md: 0 8px 32px rgba(0,0,0,.36); --shadow-lg: 0 24px 64px rgba(0,0,0,.44); --r: 10px; --r-lg: 14px; --wrap: 1160px; --font-display: "Space Grotesk", "Inter", system-ui, -apple-system, "Segoe UI", sans-serif; --font-body: "Inter", system-ui, -apple-system, "Segoe UI", "Helvetica Neue", sans-serif; --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace; } *, *::before, *::after { box-sizing: border-box; margin: 0; } html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; } body { font-family: var(--font-body); font-size: 16px; line-height: 1.6; color: var(--text); background-color: var(--bg); overflow-x: hidden; -webkit-font-smoothing: antialiased; width: 100%; } a { color: inherit; text-decoration: none; } img, svg, video, canvas { display: block; max-width: 100%; height: auto; } button, a { -webkit-tap-highlight-color: transparent; } button, input, textarea, select { font: inherit; color: inherit; } ul { list-style: none; padding: 0; } h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.8rem, 5vw, 4rem); letter-spacing: -.028em; line-height: 1.02; } h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2rem, 3.2vw, 3rem); letter-spacing: -.022em; line-height: 1.06; } h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; letter-spacing: -.016em; line-height: 1.3; } [hidden] { display: none; } .lead { font-size: 1.0625rem; line-height: 1.78; color: var(--muted); max-width: 60ch; } .eyebrow { display: inline-flex; align-items: center; height: 28px; padding: 0 12px; border-radius: 999px; border: 1px solid var(--accent-border); background: var(--accent-bg); font-family: var(--font-mono); font-size: .625rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--accent-hi); } .btn { display: inline-flex; align-items: center; justify-content: center; padding: 0 22px; border-radius: var(--r); border: 1px solid transparent; font-family: var(--font-body); font-size: .875rem; font-weight: 600; letter-spacing: -.01em; white-space: nowrap; cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease; } .btn:hover { transform: translateY(-1px); } .btn-primary { height: 44px; background: var(--accent); color: #fff; } .btn-primary:hover { background: #5B8AFF; box-shadow: 0 8px 28px rgba(79,127,255,.36); } .btn-ghost { height: 44px; background: var(--surface); border-color: var(--border); color: var(--text); } .btn-ghost:hover { background: var(--surface-2); border-color: var(--border-2); } .btn-block { width: 100%; } #toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(120%); z-index: 9999; padding: 12px 20px; background: var(--bg-2); border: 1px solid var(--border-2); border-radius: var(--r); box-shadow: var(--shadow-lg); font-size: .875rem; color: var(--text); opacity: 0; pointer-events: none; transition: transform .25s ease, opacity .25s ease; max-width: 90vw; } #toast.open { transform: translateX(-50%) translateY(0); opacity: 1; } #toast.toast-ok { border-color: var(--success-border); } #toast.toast-err { border-color: var(--danger-border); } #toast.toast-warn { border-color: var(--warn-border); } .ico{ display:inline-block; width:16px; height:16px; background-color:currentColor; -webkit-mask:var(--ico) center / contain no-repeat; mask:var(--ico) center / contain no-repeat; flex-shrink:0; vertical-align:middle; } .ico-sm{ width:12px; height:12px; } .ico-md{ width:18px; height:18px; } .ico-lg{ width:24px; height:24px; } .ico-xl{ width:28px; height:28px; } .ico-close { --ico:url(/ui/int/icon/close.svg); } .ico-eye { --ico:url(/ui/int/icon/eye.svg); } .ico-eye-off { --ico:url(/ui/int/icon/eye-off.svg); } .ico-trash { --ico:url(/ui/int/icon/trash.svg); } .ico-send { --ico:url(/ui/int/icon/send.svg); } .ico-pencil { --ico:url(/ui/int/icon/pencil.svg); } .ico-edit { --ico:url(/ui/int/icon/pencil.svg); } .ico-plus { --ico:url(/ui/int/icon/plus.svg); } .ico-log-out { --ico:url(/ui/int/icon/log-out.svg); } .ico-agent { --ico:url(/ui/int/icon/agent.svg); } .ico-account { --ico:url(/ui/int/icon/account.svg); } .ico-users { --ico:url(/ui/int/icon/users.svg); } .ico-chat { --ico:url(/ui/int/icon/chat.svg); } .ico-chat-bubble { --ico:url(/ui/int/icon/chat-bubble.svg); } .ico-doc { --ico:url(/ui/int/icon/doc.svg); } .ico-grid { --ico:url(/ui/int/icon/grid.svg); } .ico-book { --ico:url(/ui/int/icon/book.svg); } .ico-info { --ico:url(/ui/int/icon/info.svg); } .ico-bolt { --ico:url(/ui/int/icon/bolt.svg); } .ico-card { --ico:url(/ui/int/icon/card.svg); } .ico-dashboard { --ico:url(/ui/int/icon/dashboard.svg); } .ico-phone-call { --ico:url(/ui/int/icon/phone-call.svg); } .ico-phone-card { --ico:url(/ui/int/icon/phone-card.svg); } .ico-whatsapp { --ico:url(/ui/int/icon/whatsapp.svg); } .ico-mail { --ico:url(/ui/int/icon/mail.svg); } .ico-instagram { --ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='2' width='20' height='20' rx='5'/><path d='M16 11.37A4 4 0 1 1 12.63 8 4 4 0 0 1 16 11.37z'/><line x1='17.5' y1='6.5' x2='17.51' y2='6.5'/></svg>"); } .ico-reload { --ico:url(/ui/int/icon/reload.svg); } .ico-chevron-left{ --ico:url(/ui/int/icon/chevron-left.svg); } .ico-chev-down { --ico:url(/ui/int/icon/chev-down.svg); } .ico-chev-up { --ico:url(/ui/int/icon/chev-up.svg); } .ico-copy { --ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='9' y='9' width='13' height='13' rx='2'/><path d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'/></svg>"); } .ico-power-off { --ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M18.36 6.64a9 9 0 1 1-12.73 0'/><line x1='12' y1='2' x2='12' y2='12'/></svg>"); } .ico-link { --ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'/><path d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'/></svg>"); } .ico-unplug { --ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M19 5l-3 3'/><path d='M2 22l3-3'/><path d='M6.3 20.3a2.4 2.4 0 0 0 3.4 0L12 18l-6-6-2.3 2.3a2.4 2.4 0 0 0 0 3.4Z'/><path d='M7.5 13.5L10 11'/><path d='M10.5 16.5L13 14'/><path d='M12 6l6 6'/><path d='M16 8l-1 1'/><path d='M14 6l1-1'/></svg>"); } .icon-btn{ width:36px; height:36px; border-radius:8px; border:1px solid var(--border); background:var(--bg-1); color:var(--muted); display:inline-flex; align-items:center; justify-content:center; cursor:pointer; padding:0; transition:border-color .15s, background .15s, color .15s, transform .1s; flex-shrink:0; } .icon-btn:hover{ border-color:var(--accent-border); background:var(--bg-2); color:var(--text); } .icon-btn:active{ transform:scale(.94); } .icon-btn:disabled, .icon-btn[disabled]{ opacity:.4; cursor:not-allowed; pointer-events:none; } .icon-btn:focus-visible{ outline:2px solid var(--accent-hi); outline-offset:2px; } .icon-btn.icon-btn-edit:hover{ border-color:var(--accent-border); background:var(--accent-bg); color:var(--accent-hi); } .icon-btn.icon-btn-clone:hover{ border-color:var(--success-border); background:var(--success-bg); color:var(--success-hi); } .icon-btn.icon-btn-danger:hover{ border-color:var(--danger-border); background:var(--danger-bg); color:var(--danger-hi); } .icon-btn.icon-btn-success:hover{ border-color:var(--success-border); background:var(--success-bg); color:var(--success-hi); } .icon-btn.is-armed.is-confirming{ background:var(--danger-bg); border-color:var(--danger); color:var(--danger-hi); animation: btn-confirm-pulse 1.2s ease-in-out infinite; } #app.theme-light .icon-btn.is-armed.is-confirming{ background:var(--danger-bg); border-color:var(--danger); color:var(--danger-hi); } .icon-btn.icon-btn-sm{ width:30px; height:30px; border-radius:6px; } #app .btn.btn-sm, .btn.btn-sm{ height:auto; min-height:0; padding:3px 9px; font-size:12px; font-weight:500; border-radius:5px; line-height:1.3; } .btn.btn.is-armed.is-confirming{ background:var(--danger-bg); border-color:var(--danger-border); color:var(--danger-hi); animation:btn-confirm-pulse 1.2s ease-in-out infinite; } #app.theme-light .btn.btn.is-armed.is-confirming{ background:var(--danger-bg); border-color:var(--danger); color:var(--danger-hi); } @keyframes btn-confirm-pulse{ 0%, 100%{ box-shadow:0 0 0 0 transparent; } 50% { box-shadow:0 0 0 4px var(--danger-bg); } } .toggle-label{ display:flex; align-items:center; gap:12px; cursor:pointer; flex-shrink:0; } .toggle-input{ position:absolute; opacity:0; width:0; height:0; } .toggle-track{ width:44px; height:24px; border-radius:999px; border:1px solid var(--border-2); background:var(--surface); position:relative; transition:background .2s, border-color .2s; flex-shrink:0; } .toggle-input:checked ~ .toggle-track{ background:var(--accent); border-color:var(--accent); } .toggle-thumb{ position:absolute; top:3px; left:3px; width:16px; height:16px; border-radius:50%; background:var(--muted-2); transition:transform .2s, background .2s; } .toggle-input:checked ~ .toggle-track .toggle-thumb{ transform:translateX(20px); background:#fff; } .toggle-text{ font-size:.875rem; font-weight:500; color:var(--muted); transition:color .2s; } .toggle-input:checked ~ .toggle-text{ color:var(--text); } @media (max-width:960px){ #app, #landing{ width:100%; max-width:100vw; overflow-x:hidden; } input, textarea, select{ max-width:100%; } pre, code{ overflow-x:auto; max-width:100%; word-wrap:break-word; } #landing .wrap{ width:min(calc(100% - 32px), var(--wrap)); } #landing .hero h1, #landing h2, #app .mod-title{ overflow-wrap:break-word; word-break:break-word; } #app .mod-head > *, #app .mod-head-back, #app .field-wrap{ min-width:0; } #app .table-wrap, #knowledge .table-wrap{ max-width:100%; -webkit-overflow-scrolling:touch; } } @media (max-width:480px){ #landing .wrap{ width:min(calc(100% - 24px), var(--wrap)); } } #landing { display: none; } #landing.open { display: block; } #landing { --plan-base-accent: #94A3B8; --plan-base-bg: rgba(148,163,184,.06); --plan-base-border: rgba(148,163,184,.18); --plan-team-accent: #4F7FFF; --plan-team-bg: rgba(79,127,255,.08); --plan-team-border: rgba(79,127,255,.24); --plan-scale-accent: #34D399; --plan-scale-bg: rgba(52,211,153,.07); --plan-scale-border: rgba(52,211,153,.22); color: var(--text); background: var(--bg); } #landing .wrap { width: min(calc(100% - 48px), var(--wrap)); margin-inline: auto; } #landing .section { padding: 96px 0; } #landing .section + .section { border-top: 1px solid var(--border); } #landing .site-header { position: sticky; top: 0; z-index: 80; background: rgba(7,11,16,.82); backdrop-filter: blur(16px) saturate(1.4); border-bottom: 1px solid var(--border); } #landing .header-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; height: 68px; } #landing .brand { display: inline-flex; align-items: center; gap: 12px; flex-shrink: 0; transition: opacity .2s; } #landing .brand:hover { opacity: .82; } #landing .brand-logo { display: block; height: 50px; width: auto; } #landing .brand-tagline { font-size: .6875rem; color: var(--muted-2); padding-left: 12px; border-left: 1px solid var(--border); line-height: 1.2; } #landing .main-nav { display: flex; align-items: center; gap: 28px; } #landing .main-nav a { font-size: .8125rem; font-weight: 500; color: var(--muted); transition: color .15s; } #landing .main-nav a:hover { color: var(--text); } #landing .header-actions { display: flex; gap: 8px; } #landing .hero { position: relative; min-height: 92vh; display: flex; flex-direction: column; justify-content: flex-end; padding-bottom: 88px; overflow: hidden; } #landing .hero::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent 0%, #FBBF24 20%, #4F7FFF 50%, #FB7185 80%, transparent 100%); opacity: .35; z-index: 3; } #landing .hero-bg { position: absolute; inset: 0; z-index: 0; } #landing .hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; filter: saturate(.85) brightness(.85); } #landing .hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(7,11,16,.10) 0%, rgba(7,11,16,.32) 55%, rgba(7,11,16,.78) 100%), linear-gradient(100deg, rgba(7,11,16,.30) 0%, transparent 65%); } #landing .hero-grain { position: absolute; inset: 0; z-index: 1; pointer-events: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"); background-size: 220px 220px; } #landing .hero-inner { position: relative; z-index: 2; } #landing .hero-inner .eyebrow { margin-bottom: 28px; } #landing .hero h1 { max-width: 18ch; margin-bottom: 24px; color: #fff; } #landing .hero .lead { max-width: 52ch; margin-bottom: 36px; color: rgba(237,242,250,.68); } #landing .hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 56px; } #landing .btn-wa { height: 44px; gap: 8px; background: #25D366; color: #052e16; border-color: transparent; } #landing .btn-wa:hover { background: #1FBA59; box-shadow: 0 8px 28px rgba(37,211,102,.34); } #landing .btn-wa .btn-wa-icon { flex: 0 0 auto; } #landing .hero-meta { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; max-width: 700px; } #landing .hero-meta-item { background: rgba(7,11,16,.74); backdrop-filter: blur(12px); padding: 20px 24px; } #landing .hero-meta-item .label { display: block; font-family: var(--font-mono); font-size: .5875rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 8px; } #landing .hero-meta-item strong { font-size: .875rem; font-weight: 500; color: var(--text); line-height: 1.5; display: block; } #landing .strip { border-bottom: 1px solid var(--border); padding: 0; } #landing .strip-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 22px 0; } #landing .strip-copy strong { font-family: var(--font-display); font-size: .9375rem; font-weight: 700; letter-spacing: -.02em; display: block; } #landing .strip-copy p { margin-top: 4px; font-size: .8125rem; color: var(--muted); max-width: 48ch; } #landing .strip-tags { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; flex-shrink: 0; } #landing .tag { display: inline-flex; align-items: center; height: 32px; padding: 0 14px; border-radius: 999px; border: 1px solid var(--border); background: var(--surface); font-family: var(--font-mono); font-size: .5875rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); } #landing .section-header { margin-bottom: 48px; } #landing .section-header .eyebrow { margin-bottom: 20px; } #landing .section-header h2 { margin-bottom: 16px; } #landing .section-header .lead { margin-bottom: 0; } #landing .section-header.center { text-align: center; display: flex; flex-direction: column; align-items: center; } #landing .section-header.split { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,.68fr); gap: 48px; align-items: end; margin-bottom: 48px; } #landing .section-header.split .lead { max-width: 100%; margin-bottom: 0; } #landing .cards-3 { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; } #landing .card { background: var(--bg-1); padding: 32px; transition: background .2s; } #landing .card:hover { background: var(--bg-2); } #landing .card-num { font-family: var(--font-mono); font-size: .625rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 20px; display: block; } #landing .card:first-child .card-num { color: #FBBF24; } #landing .card:nth-child(2) .card-num { color: #7BA4FF; } #landing .card:last-child .card-num { color: #FB7185; } #landing .card h3 { margin-bottom: 12px; } #landing .card p { font-size: .875rem; line-height: 1.75; color: var(--muted); } #landing .steps { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; } #landing .step { padding: 36px 28px; border-right: 1px solid var(--border); background: var(--bg-1); transition: background .2s; } #landing .step:last-child { border-right: 0; } #landing .step-num { font-family: var(--font-mono); font-size: 2rem; font-weight: 700; letter-spacing: -.04em; line-height: 1; margin-bottom: 24px; display: block; } #landing .step:nth-child(1) .step-num { color: rgba(251,191,36,.18); } #landing .step:nth-child(2) .step-num { color: rgba(123,164,255,.18); } #landing .step:nth-child(3) .step-num { color: rgba(52,211,153,.18); } #landing .step:nth-child(4) .step-num { color: rgba(251,113,133,.18); } #landing .step:hover { background: var(--bg-2); } #landing .step:nth-child(1):hover { background: rgba(251,191,36,.04); } #landing .step:nth-child(2):hover { background: rgba(123,164,255,.04); } #landing .step:nth-child(3):hover { background: rgba(52,211,153,.04); } #landing .step:nth-child(4):hover { background: rgba(251,113,133,.04); } #landing .step h3 { margin-bottom: 12px; } #landing .step p { font-size: .875rem; line-height: 1.75; color: var(--muted); } #landing .feature-layout { display: grid; grid-template-columns: minmax(0,.88fr) minmax(0,1.12fr); gap: 64px; align-items: start; } #landing .feature-copy .eyebrow { margin-bottom: 20px; } #landing .feature-copy h2 { margin-bottom: 20px; } #landing .feature-copy p { font-size: .9375rem; line-height: 1.78; color: var(--muted); } #landing .feature-copy p + p { margin-top: 14px; } #landing .arch-table { border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; } #landing .arch-row { display: grid; grid-template-columns: 130px minmax(0,1fr) 150px; border-bottom: 1px solid var(--border); } #landing .arch-row:last-child { border-bottom: 0; } #landing .arch-row > div { padding: 18px 20px; font-size: .875rem; line-height: 1.65; color: var(--muted); border-right: 1px solid var(--border); } #landing .arch-row > div:last-child { border-right: 0; } #landing .arch-head > div { font-family: var(--font-mono); font-size: .5625rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-2); background: var(--surface); padding: 12px 20px; } #landing .arch-key { font-weight: 600; font-size: .875rem; color: var(--text); } #landing .arch-result { color: #34D399; font-family: var(--font-mono); font-size: .75rem; letter-spacing: .02em; } #landing .value-layout { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); gap: 20px; align-items: stretch; } #landing .value-photo { position: relative; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); min-height: 500px; } #landing .value-photo img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.65) brightness(.55); } #landing .value-photo-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(7,11,16,.96) 0%, rgba(7,11,16,.5) 38%, transparent 68%); } #landing .value-photo-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px 32px 36px; } #landing .value-photo-caption .eyebrow { margin-bottom: 14px; } #landing .value-photo-caption h3 { font-size: 1.25rem; color: var(--text); line-height: 1.35; } #landing .value-photo-caption p { margin-top: 10px; font-size: .875rem; color: var(--muted); line-height: 1.7; } #landing .value-stack { display: flex; flex-direction: column; gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; } #landing .value-card { flex: 1; background: var(--bg-1); padding: 28px 28px; transition: background .2s; } #landing .value-card:hover { background: var(--bg-2); } #landing .value-card h3 { margin-bottom: 10px; } #landing .value-card p { font-size: .875rem; line-height: 1.75; color: var(--muted); } #landing .value-stack .value-card:nth-child(1) { border-left: 2px solid rgba(251,191,36,.3); } #landing .value-stack .value-card:nth-child(2) { border-left: 2px solid rgba(79,127,255,.3); } #landing .value-stack .value-card:nth-child(3) { border-left: 2px solid rgba(52,211,153,.3); } #landing .use-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; } #landing .use-card { border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; background: var(--bg-1); transition: border-color .2s, background .2s; } #landing .use-card:hover { border-color: var(--border-2); background: var(--bg-2); } #landing .use-card:nth-child(1) { border-top: 2px solid rgba(251,191,36,.28); } #landing .use-card:nth-child(2) { border-top: 2px solid rgba(79,127,255,.28); } #landing .use-card:nth-child(3) { border-top: 2px solid rgba(251,113,133,.28); } #landing .use-card-img { aspect-ratio: 16 / 9; } #landing .use-card-img img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.6) brightness(.58); transition: filter .3s; } #landing .use-card:hover .use-card-img img { filter: saturate(.72) brightness(.66); } #landing .use-card-body { padding: 22px 24px 26px; border-top: 1px solid var(--border); } #landing .use-card-body h3 { margin-bottom: 8px; } #landing .use-card-body p { font-size: .875rem; line-height: 1.75; color: var(--muted); } #landing .pricing-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; } #landing .price-card { background: var(--bg-1); padding: 32px; display: flex; flex-direction: column; position: relative; } #landing .price-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; border-radius: 0; } #landing .price-card.featured { background: var(--bg-2); outline: 1px solid var(--accent-border); outline-offset: -1px; z-index: 1; } #landing .price-badge { display: inline-flex; align-items: center; height: 24px; padding: 0 10px; border-radius: 999px; background: var(--accent-bg); border: 1px solid var(--accent-border); font-family: var(--font-mono); font-size: .5625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--accent-hi); width: fit-content; margin-bottom: 16px; } #landing .price-name { font-family: var(--font-display); font-weight: 700; font-size: 1rem; letter-spacing: -.02em; margin-bottom: 8px; color: var(--muted); } #landing .price-amount { font-family: var(--font-display); font-weight: 800; font-size: 2.5rem; letter-spacing: -.05em; line-height: 1; color: var(--text); margin-bottom: 6px; } #landing .price-amount span { font-size: .875rem; font-weight: 500; letter-spacing: 0; color: var(--muted-2); font-family: var(--font-body); } #landing .price-capacity { font-family: var(--font-mono); font-size: .6875rem; letter-spacing: .06em; color: var(--accent-hi); margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--border); } #landing .price-desc { font-size: .875rem; line-height: 1.7; color: var(--muted); margin-bottom: 20px; } #landing .price-features { flex: 1; margin-bottom: 24px; } #landing .price-features li { display: flex; align-items: baseline; gap: 10px; font-size: .875rem; line-height: 1.65; color: var(--muted); } #landing .price-features li + li { margin-top: 10px; } #landing .price-features li::before { content: "→"; font-size: .75rem; flex-shrink: 0; } #landing .pricing-note { margin-top: 20px; text-align: center; font-size: .8125rem; color: var(--muted-2); } #landing .price-card.featured { background: linear-gradient(160deg, rgba(79,127,255,.1) 0%, rgba(79,127,255,.03) 100%); outline-color: rgba(79,127,255,.36); } #landing .price-card.featured::before { background: linear-gradient(90deg, transparent, #7BA4FF, #4F7FFF, transparent); } #landing .price-card.featured .price-amount { color: #93C5FD; } #landing .price-card.featured .price-capacity { color: #7BA4FF; } #landing .price-card.featured .price-features li::before { color: #4F7FFF; } #landing .price-card.featured .price-badge { background: rgba(79,127,255,.14); border-color: rgba(79,127,255,.3); color: #93C5FD; } #landing .price-card:last-child { background: linear-gradient(160deg, rgba(225,29,72,.07) 0%, rgba(225,29,72,.02) 100%); border-color: rgba(225,29,72,.22); } #landing .price-card:last-child::before { background: linear-gradient(90deg, transparent, #FB7185, #E11D48, transparent); } #landing .price-card:last-child .price-amount { color: #FDA4AF; } #landing .price-card:last-child .price-capacity { color: #FB7185; } #landing .price-card:last-child .price-features li::before { color: #E11D48; } #landing .price-card:last-child .btn-ghost { border-color: rgba(225,29,72,.28); color: #FDA4AF; } #landing .price-card:last-child .btn-ghost:hover { background: rgba(225,29,72,.08); border-color: rgba(225,29,72,.42); } #landing .faq-layout { display: grid; grid-template-columns: minmax(0,.68fr) minmax(0,1.32fr); gap: 72px; align-items: start; } #landing .faq-intro .eyebrow { margin-bottom: 20px; } #landing .faq-intro h2 { margin-bottom: 16px; } #landing .faq-intro p { font-size: .9375rem; line-height: 1.78; color: var(--muted); } #landing .faq-list { display: flex; flex-direction: column; gap: 8px; } #landing .faq-item { border: 1px solid var(--border); border-radius: var(--r); background: var(--bg-1); overflow: hidden; transition: border-color .15s; } #landing .faq-item[open] { border-color: var(--border-2); } #landing .faq-item summary { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 20px; font-size: .9375rem; font-weight: 600; letter-spacing: -.015em; user-select: none; } #landing .faq-item summary::-webkit-details-marker { display: none; } #landing .faq-icon { flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--border-2); display: grid; place-items: center; font-size: 15px; line-height: 1; color: var(--muted-2); transition: border-color .15s, color .15s, transform .22s; } #landing .faq-item[open] .faq-icon { border-color: var(--accent-border); color: var(--accent-hi); transform: rotate(45deg); } #landing .faq-body { padding: 16px 20px 18px; font-size: .875rem; line-height: 1.78; color: var(--muted); border-top: 1px solid var(--border); } #landing .cta-box { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 56px; align-items: center; padding: 52px 56px; border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--bg-1); position: relative; overflow: hidden; } #landing .cta-box::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, #FBBF24 30%, #4F7FFF 70%, transparent); opacity: .4; } #landing .cta-box .eyebrow { margin-bottom: 16px; } #landing .cta-box h2 { margin-bottom: 14px; } #landing .cta-box p { font-size: .9375rem; line-height: 1.75; color: var(--muted); max-width: 56ch; } #landing .cta-actions { display: flex; flex-direction: column; gap: 10px; flex-shrink: 0; min-width: 160px; } #landing .site-footer { border-top: 1px solid var(--border); padding: 32px 0 40px; } #landing .footer-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; } #landing .footer-brand-logo { display: block; height: 24px; width: auto; margin-bottom: 10px; opacity: .9; } #landing .footer-brand p { font-size: .75rem; color: var(--muted-2); } #landing .footer-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 24px; font-size: .8125rem; font-weight: 500; color: var(--muted); } #landing .footer-links a:hover { color: var(--text); transition: color .15s; } #landing .footer-legal-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--border); } #landing .footer-copy { font-size: .75rem; color: var(--muted-2); } #landing .footer-legal-links { display: flex; align-items: center; gap: 10px; font-size: .75rem; color: var(--muted); } #landing .footer-legal-links a { color: var(--muted); text-decoration: none; transition: color .15s; } #landing .footer-legal-links a:hover { color: var(--text); } #landing .footer-legal-sep { color: var(--muted-2); user-select: none; } @media (max-width: 1080px) { #landing .feature-layout, #landing .faq-layout, #landing .value-layout { grid-template-columns: 1fr; gap: 40px; } #landing .value-photo { min-height: 360px; } #landing .section-header.split { grid-template-columns: 1fr; gap: 16px; } #landing .cta-box { grid-template-columns: 1fr; gap: 28px; padding: 40px 36px; } #landing .cta-actions { flex-direction: row; flex-wrap: wrap; } #landing .strip-tags { display: none; } } @media (max-width: 860px) { #landing .wrap { width: min(calc(100% - 32px), var(--wrap)); } #landing .section { padding: 72px 0; } #landing .main-nav { display: none; } #landing .header-row { height: 60px; } #landing .hero { min-height: 80vh; padding-bottom: 64px; } #landing .hero-meta { grid-template-columns: 1fr; max-width: 100%; } #landing .hero-meta-item { padding: 16px 20px; } #landing .cards-3, #landing .pricing-grid, #landing .use-grid { grid-template-columns: 1fr; } #landing .steps { grid-template-columns: 1fr 1fr; } #landing .step { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); } #landing .step:nth-child(2n) { border-right: 0; } #landing .step:nth-child(3), #landing .step:nth-child(4) { border-bottom: 0; } #landing .price-card.featured { outline: none; border-top: 1px solid var(--accent-border); border-bottom: 1px solid var(--accent-border); } #landing .arch-row { grid-template-columns: 1fr; } #landing .arch-row > div { border-right: 0; border-bottom: 1px solid var(--border); } #landing .arch-row > div:last-child { border-bottom: 0; } #landing .arch-head { display: none; } #landing .footer-row { flex-direction: column; align-items: flex-start; gap: 20px; } #landing .footer-links { justify-content: flex-start; } #landing .footer-legal-row { flex-direction: column; align-items: flex-start; gap: 10px; } } @media (max-width: 600px) { #landing .hero { min-height: 75vh; padding-bottom: 56px; } #landing .hero-actions .btn { flex: 1 1 100%; } #landing .cta-box { padding: 28px 24px; } #landing .cta-actions { flex-direction: column; } #landing .cta-actions .btn { width: 100%; } #landing .header-actions .btn-ghost { display: inline-flex; height: 38px; padding: 0 14px; font-size: .8125rem; } #landing .header-actions .btn-primary { height: 38px; padding: 0 16px; font-size: .8125rem; } #landing .header-actions { gap: 6px; } #landing .brand-tagline { display: none; } #landing .brand-logo { height: 42px; } #landing .header-row { gap: 12px; } } @media (max-width: 420px) { #landing .header-actions .btn-ghost, #landing .header-actions .btn-primary { padding: 0 12px; font-size: .75rem; } } #landing .pricing-free-banner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 28px 32px; margin-bottom: 32px; background: linear-gradient(135deg, rgba(34,197,94,.08) 0%, rgba(34,197,94,.02) 100%); border: 1px solid rgba(34,197,94,.22); border-radius: 18px; position: relative; overflow: hidden; } #landing .pricing-free-banner::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, transparent, #22c55e, #16a34a, transparent); } #landing .pricing-free-content { flex: 1; min-width: 0; } #landing .pricing-free-eyebrow { font-size: .75rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: #22c55e; margin-bottom: 6px; } #landing .pricing-free-title { font-size: 1.75rem; font-weight: 700; color: var(--text); margin-bottom: 10px; line-height: 1.2; } #landing .pricing-free-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: .9375rem; color: var(--text); margin-bottom: 10px; font-weight: 500; } #landing .pricing-free-meta .dot { color: var(--muted-2); opacity: .6; } #landing .pricing-free-desc { font-size: .875rem; color: var(--muted); margin: 0; line-height: 1.55; max-width: 640px; } #landing .btn-lg { padding: 14px 28px; font-size: 1rem; font-weight: 600; flex-shrink: 0; } @media (max-width: 720px) { #landing .pricing-free-banner { flex-direction: column; align-items: flex-start; padding: 22px; gap: 16px; } #landing .pricing-free-title { font-size: 1.5rem; } #landing .btn-lg { width: 100%; text-align: center; } } #landing .pricing-packs { margin-top: 48px; padding: 36px; background: var(--bg-2); border: 1px solid var(--border); border-radius: 18px; } #landing .pricing-packs-head { text-align: center; margin-bottom: 24px; } #landing .pricing-packs-head h3 { font-size: 1.375rem; font-weight: 600; color: var(--text); margin: 0 0 8px 0; } #landing .pricing-packs-head p { font-size: .9375rem; color: var(--muted); margin: 0; max-width: 600px; margin-left: auto; margin-right: auto; } #landing .pricing-packs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; } #landing .pack-card { padding: 22px 20px; background: var(--bg); border: 1px solid var(--border); border-radius: 12px; text-align: center; transition: border-color .15s ease, transform .15s ease; } #landing .pack-card:hover { border-color: rgba(168,85,247,.4); transform: translateY(-2px); } #landing .pack-name { font-size: .8125rem; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; } #landing .pack-amount { font-size: 1.875rem; font-weight: 700; color: var(--text); line-height: 1; margin-bottom: 6px; } #landing .pack-credits { font-size: 1rem; font-weight: 600; color: #a855f7; margin-bottom: 4px; } #landing .pack-rate { font-size: .8125rem; color: var(--muted-2); } #landing .pricing-packs-note { margin-top: 20px; text-align: center; font-size: .8125rem; color: var(--muted-2); } @media (max-width: 720px) { #landing .pricing-packs { padding: 24px 18px; } #landing .pricing-packs-grid { grid-template-columns: 1fr; gap: 12px; } #landing .pack-card { padding: 18px 16px; } } #landing .footer-contact { display: flex; flex-direction: column; gap: 9px; font-size: .8125rem; } #landing .footer-contact-title { font-weight: 600; color: var(--text); margin-bottom: 2px; } #landing .footer-contact a { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); text-decoration: none; transition: color .15s; } #landing .footer-contact a:hover { color: var(--text); } #landing .footer-contact .ico { opacity: .85; } #landing .wa-fab { position: fixed; right: 22px; bottom: 22px; height: 44px; padding: 0 14px 0 11px; border-radius: 22px; background: #25D366; color: #fff; display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 13.5px; line-height: 1; text-decoration: none; box-shadow: 0 6px 18px rgba(0,0,0,.22); z-index: 900; transition: transform .15s, box-shadow .15s; } #landing .wa-fab:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 10px 24px rgba(37,211,102,.38); } #landing .wa-fab .ico { width: 22px; height: 22px; flex: 0 0 auto; } #landing .wa-fab .wa-fab-text { white-space: nowrap; } @media (max-width: 700px) { #landing .wa-fab { right: 16px; bottom: 16px; height: 42px; padding: 0 13px 0 10px; font-size: 13px; gap: 6px; } #landing .wa-fab .ico { width: 20px; height: 20px; } } #login, #register { position: fixed; inset: 0; z-index: 120; overflow: auto; } #login::before, #register::before { content: ""; position: fixed; inset: 0; background: rgba(7,11,16,.36); backdrop-filter: blur(14px) saturate(1.05); -webkit-backdrop-filter: blur(14px) saturate(1.05); } #login .auth-main, #register .auth-main { position: relative; z-index: 1; min-height: 100vh; padding: 32px 24px; } body.auth-open { overflow: hidden; } .auth-body { min-height: 100vh; display: flex; flex-direction: column; background: var(--bg); } .auth-bg { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; } .auth-bg-glow { position: absolute; border-radius: 50%; filter: blur(80px); } .auth-bg-glow-a { width: 600px; height: 600px; top: -200px; left: -100px; background: radial-gradient(circle, rgba(79,127,255,.09) 0%, transparent 70%); } .auth-bg-glow-b { width: 400px; height: 400px; bottom: -100px; right: -80px; background: radial-gradient(circle, rgba(52,211,153,.06) 0%, transparent 70%); } .auth-bg-grid { position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px); background-size: 48px 48px; mask-image: linear-gradient(to bottom, rgba(0,0,0,.6), transparent 90%); } .auth-header { position: relative; z-index: 10; padding: 20px 0; border-bottom: 1px solid var(--border); background: rgba(7,11,16,.72); backdrop-filter: blur(12px); } .auth-header .brand { display: inline-flex; align-items: center; gap: 10px; padding: 0 32px; } .auth-main { position: relative; z-index: 1; flex: 1; display: flex; align-items: center; justify-content: center; padding: 48px 24px; } .auth-card { display: grid; grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr); width: 100%; max-width: 900px; border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; background: var(--bg-1); box-shadow: 0 32px 80px rgba(0,0,0,.5); } .auth-card-wide { max-width: 1040px; } .auth-card { position: relative; } .auth-close { position: absolute; top: 16px; right: 16px; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 999px; border: 1px solid var(--border); background: rgba(7,11,16,.58); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); color: var(--muted); transition: background .15s, border-color .15s, color .15s, transform .15s; z-index: 3; } .auth-close:hover { background: rgba(255,255,255,.08); border-color: var(--border-2); color: var(--text); transform: translateY(-1px); } .auth-close svg { width: 16px; height: 16px; display: block; } .auth-side { background: linear-gradient(160deg, rgba(79,127,255,.08) 0%, rgba(79,127,255,.02) 60%, transparent 100%), var(--bg-2); border-right: 1px solid var(--border); padding: 48px 40px; display: flex; flex-direction: column; justify-content: center; } .auth-side-inner { max-width: 340px; } .auth-side .eyebrow { margin-bottom: 20px; } .auth-side-title { font-family: "Bricolage Grotesque", sans-serif; font-weight: 800; font-size: clamp(1.6rem, 2.4vw, 2.2rem); letter-spacing: -.028em; line-height: 1.1; margin-bottom: 16px; color: var(--text); } .auth-side-desc { font-size: .9375rem; line-height: 1.75; color: var(--muted); margin-bottom: 32px; } .auth-feature-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 32px; } .auth-feature-list li { display: flex; align-items: baseline; gap: 12px; font-size: .875rem; color: var(--muted); line-height: 1.5; } .auth-feature-icon { font-size: .75rem; color: var(--accent); flex-shrink: 0; margin-top: 1px; } .auth-plan-hint { margin-top: 8px; padding: 16px 18px; border: 1px solid var(--accent-border); border-radius: var(--r); background: var(--accent-bg); } .auth-plan-hint .label { display: block; font-family: "JetBrains Mono", monospace; font-size: .5875rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 8px; } .auth-plan-hint-body { display: flex; flex-direction: column; gap: 3px; } .auth-plan-hint-body strong { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1rem; letter-spacing: -.02em; color: var(--accent-hi); } .auth-plan-hint-body span { font-family: "JetBrains Mono", monospace; font-size: .6875rem; color: var(--muted-2); letter-spacing: .04em; } .auth-form-side { padding: 48px 44px; display: flex; align-items: center; } .auth-form-wrap { width: 100%; } .auth-form-header { margin-bottom: 28px; } .auth-form-title { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 1.5rem; letter-spacing: -.022em; color: var(--text); margin-bottom: 6px; } .auth-form-sub { font-size: .8125rem; color: var(--muted); } .auth-form-sub a { color: var(--accent-hi); font-weight: 500; transition: color .15s; } .auth-form-sub a:hover { color: var(--text); } .auth-alert { display: flex; align-items: flex-start; gap: 10px; padding: 12px 16px; border-radius: var(--r); font-size: .875rem; line-height: 1.55; margin-bottom: 20px; border: 1px solid; } .auth-alert.alert-error { background: rgba(225,29,72,.08); border-color: rgba(225,29,72,.22); color: #FDA4AF; } .auth-alert.alert-success { background: rgba(52,211,153,.08); border-color: rgba(52,211,153,.22); color: #6EE7B7; } .auth-form { display: flex; flex-direction: column; gap: 18px; } .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; } .field-group { display: flex; flex-direction: column; gap: 6px; } .field-label-row { display: flex; align-items: center; justify-content: space-between; } .field-label { font-size: .8125rem; font-weight: 600; color: var(--text); letter-spacing: -.01em; } .field-link { font-size: .75rem; color: var(--muted-2); transition: color .15s; } .field-link:hover { color: var(--accent-hi); } .field-wrap { position: relative; } .field-wrap-icon .field-input { padding-right: 44px; } .field-input { width: 100%; height: 44px; padding: 0 14px; background: rgba(255,255,255,.04); border: 1px solid var(--border); border-radius: var(--r); font-family: "DM Sans", sans-serif; font-size: .9375rem; color: var(--text); outline: none; transition: border-color .15s, background .15s, box-shadow .15s; -webkit-appearance: none; } .field-input::placeholder { color: var(--muted-2); } .field-input:hover { border-color: var(--border-2); } .field-input:focus { border-color: var(--accent); background: rgba(79,127,255,.04); box-shadow: 0 0 0 3px rgba(79,127,255,.12); } .field-input.is-error { border-color: rgba(225,29,72,.5); box-shadow: 0 0 0 3px rgba(225,29,72,.1); } .field-input.is-valid { border-color: rgba(52,211,153,.4); } .field-error { font-size: .75rem; color: #FB7185; min-height: 16px; line-height: 1.4; display: block; } .field-toggle-pw { position: absolute; right: 0; top: 0; bottom: 0; width: 44px; display: grid; place-items: center; background: none; border: none; color: var(--muted-2); cursor: pointer; transition: color .15s; } .field-toggle-pw:hover { color: var(--text); } .field-check-group { margin-top: 2px; } .field-check { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; } .field-check input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; } .field-check-box { flex-shrink: 0; width: 18px; height: 18px; border-radius: 5px; border: 1px solid var(--border-2); background: var(--surface); display: grid; place-items: center; margin-top: 1px; transition: background .15s, border-color .15s; } .field-check input:checked ~ .field-check-box { background: var(--accent); border-color: var(--accent); } .field-check input:checked ~ .field-check-box::after { content: ""; display: block; width: 5px; height: 9px; border: 2px solid #fff; border-top: 0; border-left: 0; transform: rotate(45deg) translateY(-1px); } .field-check-label { font-size: .8125rem; color: var(--muted); line-height: 1.5; } .field-check-label a { color: var(--accent-hi); transition: color .15s; } .field-check-label a:hover { color: var(--text); } .pw-strength { display: flex; align-items: center; gap: 10px; margin-top: -8px; } .pw-strength-bar { flex: 1; height: 3px; background: var(--border); border-radius: 999px; overflow: hidden; } .pw-strength-fill { height: 100%; border-radius: 999px; width: 0%; transition: width .3s ease, background .3s ease; } .pw-strength-label { font-family: "JetBrains Mono", monospace; font-size: .5875rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; white-space: nowrap; color: var(--muted-2); } .btn-auth { height: 48px; font-size: .9375rem; margin-top: 4px; position: relative; } .btn-spinner { width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin .7s linear infinite; position: absolute; right: 16px; } @keyframes spin { to { transform: rotate(360deg); } } .auth-divider-text { display: flex; align-items: center; gap: 12px; font-size: .75rem; color: var(--muted-2); margin: 20px 0 0; text-align: center; } .auth-divider-text::before, .auth-divider-text::after { content: ""; flex: 1; height: 1px; background: var(--border); } .auth-register-cta { font-size: .875rem; color: var(--muted); margin-top: 0; } .auth-footer-note { margin-top: 18px; font-size: .75rem; color: var(--muted-2); line-height: 1.6; text-align: center; } @media (max-width: 860px) { .auth-card { grid-template-columns: 1fr; max-width: 520px; } .auth-side { display: none; } .auth-form-side { padding: 36px 32px; } } @media (max-width: 600px) { .auth-main { padding: 24px 16px; } .auth-form-side { padding: 28px 24px; } .field-row { grid-template-columns: 1fr; } .auth-header .brand { padding: 0 20px; } } @media (max-width: 860px) { .auth-close { top: 12px; right: 12px; } } #login, #register { opacity: 0; pointer-events: none; transition: opacity .22s ease; } #login .auth-card, #register .auth-card { opacity: 0; transform: translate3d(0, 3rem, 0); transition: opacity .24s ease, transform .28s cubic-bezier(.22,.8,.2,1); will-change: opacity, transform; } #login.open, #register.open { display: block; opacity: 1; pointer-events: auto; } #login.open .auth-card, #register.open .auth-card { opacity: 1; transform: translate3d(0, 0, 0); } .auth-side-panel { display: none; } .auth-side-panel.open { display: block; } .auth-panel { display: none; } .auth-panel.open { display: block; } .auth-alert { display: none; } .auth-alert.open { display: flex; } .pw-strength { display: none; } .pw-strength.open { display: flex; } .btn-spinner { display: none; } .btn-spinner.open { display: flex; } .auth-plan-pricing { display: flex; align-items: baseline; gap: 6px; margin: 16px 0 24px 0; } .auth-plan-pricing-amount { font-size: 2.5rem; font-weight: 800; color: var(--text); line-height: 1; } .auth-plan-pricing-period { font-size: 1rem; color: var(--muted); font-weight: 500; } .auth-plan-flow-note { margin-top: 24px; padding: 12px 14px; font-size: 0.8125rem; color: var(--muted); background: rgba(168, 85, 247, 0.06); border: 1px solid rgba(168, 85, 247, 0.18); border-radius: 8px; line-height: 1.5; } .auth-skip-checkout { display: block; margin-top: 14px; text-align: center; font-size: 0.875rem; color: var(--muted); text-decoration: none; transition: color 0.15s ease; } .auth-skip-checkout:hover { color: var(--accent-hi); text-decoration: underline; } #app.theme-light{ --bg: #E6EEFB; --bg-1: #FFFFFF; --bg-2: #EDF2FA; --bg-3: #DBE5F5; --border: rgba(30,58,138,.14); --border-2: rgba(30,58,138,.20); --border-3: rgba(30,58,138,.30); --text: #0C1B3F; --muted: #475569; --muted-2: #64748B; --accent: #1D4ED8; --accent-hi: #1E40AF; --accent-bg: rgba(29,78,216,.08); --accent-border: rgba(29,78,216,.26); --accent-strong: rgba(29,78,216,.16); --accent-light: #3B82F6; --shadow-sm: 0 1px 2px rgba(30,58,138,.06); --shadow-md: 0 1px 2px rgba(30,58,138,.06), 0 4px 14px rgba(30,58,138,.08); --shadow-lg: 0 4px 8px rgba(30,58,138,.08), 0 16px 40px rgba(30,58,138,.14); --shadow-xl: 0 8px 16px rgba(30,58,138,.10), 0 32px 80px rgba(30,58,138,.20); --shadow-brand: 0 8px 24px rgba(29,78,216,.12); --focus-ring: 0 0 0 3px rgba(29,78,216,.20); background: var(--bg); } #app.theme-light .mod-title{ letter-spacing:-0.035em; } #app.theme-light .nav-credits-label, #app.theme-light .metric-label, #app.theme-light .plan-eyebrow, #app.theme-light .plan-usage-label, #app.theme-light .dash-section-title{ font-family:var(--font-mono); font-size:10.5px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; } #app.theme-light .nav-credits-label{ color:var(--accent); font-size:10px; letter-spacing:0.18em; } #app.theme-light .metric-value, #app.theme-light .nav-credits-balance, #app.theme-light #plan-credits-total, #app.theme-light #plan-credits-monthly, #app.theme-light #plan-credits-extra, #app.theme-light .plan-card-amount, #app.theme-light .plan-pack-credits strong, #app.theme-light .plan-option-price strong, #app.theme-light .plan-feat-credits{ font-feature-settings:'tnum'; font-variant-numeric:tabular-nums; letter-spacing:-0.025em; } #app.theme-light .nav-credits-balance{ font-size:16px; font-weight:700; } #app.theme-light .nav-credits-foot, #app.theme-light .plan-credits-cycle, #app.theme-light .plan-usage-pct, #app.theme-light .metric-cap{ font-family:var(--font-mono); font-feature-settings:'tnum'; font-size:10.5px; } #app.theme-light .form-sections, #app.theme-light #dash .dash-section, #app.theme-light #dash .dash-metrics, #app.theme-light #plan .plan-card, #app.theme-light #plan .plan-section, #app.theme-light #plan .plan-option, #app.theme-light #plan .plan-pack, #app.theme-light #agents .agent-card, #app.theme-light #lines .line-card, #app.theme-light #knowledge .kn-card, #app.theme-light #interactions .int-conv, #app.theme-light .nav-credits{ box-shadow:var(--shadow-md); } #app.theme-light #plan .plan-card, #app.theme-light #plan .plan-option.is-current, #app.theme-light #plan .plan-pack:hover, #app.theme-light #agents .agent-card:hover, #app.theme-light #lines .line-card:hover{ box-shadow:var(--shadow-md),var(--shadow-brand); } #app.theme-light .nav-credits{ border-color:var(--accent-border); box-shadow:var(--shadow-md),0 0 0 1px var(--accent-bg); } #app.theme-light .nav-credits-bar-fill, #app.theme-light #plan .plan-bar-fill, #app.theme-light #plan-credits-bar, #app.theme-light #dash .dash-plan-bar-fill:not([data-level="warn"]):not([data-level="danger"]){ background:linear-gradient(90deg,var(--accent),var(--accent-light)); } #app.theme-light .nav-credits.is-low .nav-credits-bar-fill{ background:linear-gradient(90deg,var(--warn),var(--warn-hi)); } #app.theme-light .nav-credits.is-empty .nav-credits-bar-fill{ background:var(--danger); } #app.theme-light #plan .plan-option.is-current .plan-option-badge{ background:var(--accent); border-color:var(--accent); color:#FFFFFF; box-shadow:0 4px 12px rgba(29,78,216,.32); font-weight:700; letter-spacing:0.05em; } #app.theme-light .btn:hover{ background:var(--accent-hi); box-shadow:0 4px 14px rgba(29,78,216,.32), 0 1px 2px rgba(30,58,138,.10); } #app.theme-light .field-input:focus, #app.theme-light .field-textarea:focus, #app.theme-light .combo .spot:focus{ border-color:var(--accent); box-shadow:var(--focus-ring); } #app.theme-light .nav-link.on{ background:var(--accent-strong); color:var(--accent-hi); font-weight:600; box-shadow:inset 2px 0 0 var(--accent); } #app.theme-light .nav-user-avatar{ box-shadow:0 0 0 1px var(--accent-border), 0 2px 6px rgba(29,78,216,.10); } #app.theme-light .combo .list{ box-shadow:var(--shadow-lg); border-color:var(--border-2); } #app.theme-light{ scrollbar-color:rgba(30,58,138,.26) transparent; } #app.theme-light ::-webkit-scrollbar-thumb{ background:rgba(30,58,138,.26); } #app.theme-light ::-webkit-scrollbar-thumb:hover{ background:rgba(30,58,138,.38); } 