:root{color-scheme:light;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.4;--brand: #0f6cbd;--brand-hover: #115ea3;--surface: #ffffff;--bg: #f3f2f1;--stroke: #d1d1d1;--stroke-subtle: #e8e8e8;--fg: #242424;--fg-2: #616161;--danger: #c50f1f;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 16px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--fg);overflow:hidden}#root{display:flex;flex-direction:column;min-height:0}a{color:var(--brand)}.app-header{height:52px;flex-shrink:0;background:linear-gradient(135deg,#0a4f8e,#0f6cbd,#2a8be0);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 2px 8px #0f6cbd2e;display:flex;align-items:center;padding:0 16px;gap:6px;z-index:100;color:#fff}.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;flex-shrink:0;padding:0 6px}.brand img{width:32px;height:32px;border-radius:8px;display:block;filter:drop-shadow(0 0 .5px rgba(255,255,255,.95)) drop-shadow(0 0 2px rgba(255,255,255,.6)) drop-shadow(0 2px 6px rgba(0,0,0,.35));transition:filter .15s ease,transform .15s ease}.brand:hover img{filter:drop-shadow(0 0 .5px rgba(255,255,255,1)) drop-shadow(0 0 4px rgba(255,255,255,.7)) drop-shadow(0 3px 8px rgba(0,0,0,.4));transform:translateY(-1px)}.brand-name{font-size:16px;font-weight:700;letter-spacing:-.2px;color:#fff}.header-mid{flex:1;display:flex;align-items:center;min-width:0;overflow:visible}.detail-bar{display:flex;align-items:center;gap:6px;width:100%}.detail-title{flex:1;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff}.header-btn{display:inline-flex;align-items:center;gap:6px;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);border-radius:6px;padding:5px 12px;font-size:13px;font-family:inherit;font-weight:500;color:#fff;cursor:pointer;transition:background .12s,border-color .12s;white-space:nowrap;flex-shrink:0}.header-btn:hover:not(:disabled){background:#ffffff38;border-color:#ffffff59}.header-btn:disabled{cursor:not-allowed;opacity:.55}.header-btn.subtle{background:transparent;border-color:transparent;color:#ffffffd9}.header-btn.subtle:hover{background:#ffffff29;color:#fff}.header-btn.active{background:linear-gradient(135deg,#ffb347,#ffcc70);border-color:#f0a030;color:#5a3000;font-weight:600;box-shadow:inset 0 1px #fff6}.header-btn.danger{background:#ffffff1f;border-color:#ffffff38;color:#fff}.header-btn.danger:hover:not(:disabled){background:#e53e3ed9;border-color:#e53e3ef2;color:#fff}.detail-bar-secondary{display:contents}.header-more-wrap{position:relative;display:none;flex-shrink:0}.header-more-trigger{padding:5px 9px;font-size:18px;line-height:1}.header-more-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:200;min-width:220px;background:var(--surface);border:1px solid var(--stroke-subtle);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:6px;display:flex;flex-direction:column;gap:2px}.header-more-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border:0;background:transparent;border-radius:6px;color:var(--fg);font-family:inherit;font-size:14px;font-weight:500;text-align:left;cursor:pointer;width:100%}.header-more-item:hover:not(:disabled){background:var(--bg)}.header-more-item:disabled{opacity:.55;cursor:not-allowed}.header-more-item.danger{color:var(--danger)}.header-more-item.danger:hover:not(:disabled){background:#e53e3e1a}.header-more-icon{flex:0 0 20px;width:20px;display:inline-flex;align-items:center;justify-content:center;font-size:15px}.header-more-label{flex:1}@media(max-width:1100px){.detail-bar-secondary{display:none}.header-more-wrap{display:inline-flex;margin-left:auto}}@media(max-width:560px){.app-header{padding:0 10px;gap:4px}.brand-name{display:none}.brand{padding:0 4px}}.avatar-wrap{position:relative;margin-left:6px}.header-actions{display:flex;align-items:center;gap:8px}.help-wrap{position:relative}.help-btn{width:30px;height:30px;border-radius:50%;background:transparent;color:#fff;font-size:14px;font-weight:700;font-family:inherit;border:1px solid rgba(255,255,255,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,transform .12s}.help-btn:hover,.help-btn[aria-expanded=true]{background:#ffffff26;transform:translateY(-1px)}.help-popover{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--surface);color:var(--fg);border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:12px 14px;z-index:200}.help-popover-title{font-weight:600;font-size:13px;margin-bottom:6px}.help-popover-body{margin:0;font-size:13px;color:var(--fg-2);line-height:1.4}.help-popover-body a{color:var(--accent, #0a4f8e);font-weight:500;text-decoration:none}.help-popover-body a:hover{text-decoration:underline}.avatar-btn{width:34px;height:34px;border-radius:50%;background:#fff;color:#0a4f8e;font-size:12px;font-weight:700;font-family:inherit;letter-spacing:.3px;border:1px solid rgba(255,255,255,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s,box-shadow .12s;box-shadow:0 1px 3px #0000002e}.avatar-btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000038}.user-menu{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--surface);border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;z-index:200}.user-menu-head{display:flex;align-items:center;gap:12px;padding:14px 16px}.avatar-lg{width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;font-size:16px;font-weight:700;flex-shrink:0;display:flex;align-items:center;justify-content:center}.user-info{min-width:0}.user-info-name{font-weight:700;font-size:15px;line-height:1.2;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info-email{font-size:12px;color:var(--fg-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:4px}.menu-sep{border:none;border-top:1px solid var(--stroke-subtle);margin:0}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:14px;color:var(--fg);text-decoration:none;cursor:pointer;transition:background .1s;border:none;background:none;width:100%;font-family:inherit}.menu-item:hover{background:#f5f5f5}.menu-item.danger{color:var(--danger)}.app-layout,.auth-layout{flex:1;min-height:0;overflow-y:auto;width:100%;display:grid;gap:16px;padding:24px 16px;align-content:start;justify-items:stretch;grid-template-columns:minmax(0,1000px);justify-content:center}.detail-layout{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;overflow:hidden}.detail-frame-wrap{flex:1;display:flex;flex-direction:column;background:var(--surface);min-height:0;overflow:hidden}.detail-frame-wrap.review{outline:2px solid #93c5fd;outline-offset:-2px}.detail-frame-row{flex:1;display:grid;grid-template-columns:minmax(0,1fr);min-height:0;overflow:hidden}.detail-frame-wrap.review .detail-frame-row{grid-template-columns:minmax(0,1fr) 360px}.detail-preview-wrap{position:relative;display:flex;min-height:0;overflow:hidden;background:#fff}.detail-frame{flex:1;width:100%;height:100%;border:none;background:#fff;display:block}.detail-frame-overlay{position:absolute;inset:0;background:#ffffffd9;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:2;animation:fade-in .15s ease-out}.detail-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--fg-2)}.detail-empty-text{font-size:13px}.loading-spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;flex:1;width:100%;min-height:200px;padding:24px;color:var(--fg-2)}.loading-spinner{display:block;width:44px;height:44px;border-radius:50%;border:3px solid #e3e8ef;border-top-color:var(--brand);animation:loading-spin .9s linear infinite;box-shadow:0 4px 12px #0f6cbd2e}.loading-spinner-sm .loading-spinner{width:28px;height:28px;border-width:2.5px;box-shadow:none}.loading-spinner-md .loading-spinner{width:36px;height:36px}.loading-spinner-label{font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--fg-2)}@keyframes loading-spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.presentation-exit-btn{position:fixed;top:12px;right:12px;z-index:400;width:36px;height:36px;border-radius:50%;border:none;background:#0f6cbdd9;color:#fff;font-size:18px;line-height:1;cursor:pointer;box-shadow:0 2px 6px #00000038;transition:background .15s,transform .15s}.presentation-exit-btn:hover{background:var(--brand-hover);transform:scale(1.05)}.review-panel{border-left:1px solid var(--stroke-subtle);background:var(--surface);display:flex;flex-direction:column;min-height:0}.review-panel-header{padding:12px 14px;border-bottom:1px solid var(--stroke-subtle)}.review-panel-title{font-size:14px;font-weight:700;margin-bottom:2px}.review-panel-subtitle{font-size:12px;color:var(--fg-2)}.review-comment-list{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;position:relative;background:#f9fafc}.review-comment-canvas,.review-comment-items-layer{position:relative;min-height:100%}.review-empty{color:var(--fg-2);font-size:12px;text-align:center;padding:14px 8px;border:1px dashed var(--stroke);border-radius:8px;background:#fafafa;margin:10px 12px 12px}.review-selection-draft{position:absolute;left:12px;right:12px;z-index:3;padding:10px;border:1px solid #f3d17d;border-radius:8px;background:#fffdf5;box-shadow:0 1px 4px #00000014}.review-selection-caption{font-size:11px;color:var(--fg-2);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.review-selection-text{font-size:12px;color:var(--fg);background:#fff4ce;border:1px solid #fcd980;border-radius:6px;padding:8px;margin-bottom:8px;max-height:92px;overflow:auto;white-space:pre-wrap}.review-textarea{width:100%;min-height:74px;resize:vertical;border:1px solid var(--stroke);border-radius:6px;padding:8px;font-family:inherit;font-size:13px;margin-bottom:8px}.review-selection-actions{display:flex;justify-content:flex-end;gap:8px}.review-comment-item{border:1px solid var(--stroke-subtle);border-radius:8px;background:#fff;padding:10px;cursor:pointer;transition:border-color .12s,box-shadow .12s,background-color .12s;position:absolute;left:12px;right:12px}.review-comment-item:hover{border-color:#c7e0f4;background:#fcfdff}.review-comment-item.active{border-color:#60a5fa;box-shadow:0 0 0 2px #2563eb29;background:#f8fbff}.review-comment-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.review-author{font-size:12px;font-weight:600;color:var(--fg)}.review-time{font-size:11px;color:#8a8a8a;margin-left:6px;font-weight:400}.review-version-chip{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;background:#eff6fc;color:#0f6cbd;font-size:10px;font-weight:700;letter-spacing:.02em;vertical-align:middle}.version-menu-wrap{position:relative;flex-shrink:0}.version-menu-trigger{gap:8px}.version-menu-chevron{font-size:11px;opacity:.85;margin-left:2px}.version-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:var(--surface);border:1px solid var(--stroke);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;padding:4px 0;z-index:200}.version-menu-section-title{padding:6px 14px 4px;font-size:11px;font-weight:600;color:var(--fg-2);text-transform:uppercase;letter-spacing:.04em}.version-menu-item{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:14px;color:var(--fg);text-decoration:none;cursor:pointer;transition:background .1s;border:none;background:none;width:100%;font-family:inherit;text-align:left}.version-menu-item:hover:not(:disabled){background:#f5f5f5}.version-menu-item:disabled{cursor:not-allowed;opacity:.55}.version-menu-item.active{color:var(--brand);font-weight:600}.version-menu-item.add-new{color:var(--brand);font-weight:500}.version-menu-row{display:flex;align-items:stretch;position:relative}.version-menu-row:hover{background:#f5f5f5}.version-menu-row>.version-menu-item{flex:1;min-width:0;padding-right:8px}.version-menu-row>.version-menu-item:hover:not(:disabled){background:transparent}.version-menu-delete{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:28px;margin-right:8px;border:0;background:transparent;border-radius:4px;color:#8a8a8a;font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s,background .12s,color .12s}.version-menu-row:hover .version-menu-delete,.version-menu-row:focus-within .version-menu-delete{opacity:1}.version-menu-delete:hover{background:#c50f1f1a;color:var(--danger)}.version-menu-delete:focus-visible{outline:2px solid var(--danger);outline-offset:-2px;opacity:1}@media(hover:none){.version-menu-delete{opacity:1}}.version-menu-check{display:inline-flex;width:16px;height:16px;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.version-menu-label{flex:1;min-width:0}.version-pill{display:inline-block;padding:2px 8px;border-radius:10px;background:#eff6fc;color:#0f6cbd;font-size:11px;font-weight:700}.review-state-select{border:1px solid var(--stroke);border-radius:4px;font-size:12px;padding:2px 6px;color:var(--fg);background:#fff}.review-comment-text{font-size:13px;color:var(--fg);line-height:1.4;white-space:pre-wrap;margin-bottom:8px}.review-anchor-snippet{font-size:12px;color:#7a5f00;background:#fff4ce;border:1px solid #fce08a;border-radius:6px;padding:6px 8px;margin-bottom:8px}.review-anchor-snippet-text{white-space:pre-wrap;word-break:break-word;max-height:96px;overflow:hidden}.review-anchor-snippet.expanded .review-anchor-snippet-text{max-height:240px;overflow:auto}.review-anchor-snippet-toggle{margin-top:4px;background:none;border:none;padding:0;font:inherit;color:#0f6cbd;cursor:pointer;text-decoration:underline;font-size:11px}.review-anchor-snippet-toggle:hover{color:var(--brand-hover)}.review-replies{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.review-reply-item{border-left:2px solid #deecf9;padding-left:8px}.review-reply-meta{font-size:11px;color:var(--fg-2);margin-bottom:2px}.review-reply-text{font-size:12px;color:var(--fg);white-space:pre-wrap;line-height:1.35}.review-reply-compose{display:grid;grid-template-columns:1fr auto;gap:6px}.review-reply-input{border:1px solid var(--stroke);border-radius:4px;font-size:12px;padding:6px 8px;width:100%}@media(max-width:1100px){.detail-frame-wrap.review .detail-frame-row{grid-template-columns:minmax(0,1fr)}.review-panel{border-left:none;border-top:1px solid var(--stroke-subtle);max-height:46vh}}.card{background:var(--surface);border:1px solid var(--stroke-subtle);border-radius:10px;padding:16px}.card h1,.card h2{margin:0 0 8px}.gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.gallery-head-text h1{margin:0;font-size:22px;letter-spacing:-.4px;color:var(--fg)}.gallery-head-sub{margin:4px 0 0;color:var(--fg-2);font-size:13px}.gallery-new-btn{gap:6px;padding:9px 16px;white-space:nowrap}.gallery-new-btn span{font-size:16px;line-height:1}.gallery-toolbar{display:flex;flex-direction:column;gap:10px}.gallery-wrap{display:flex;flex-direction:column;gap:16px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.g-card{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--stroke-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .15s ease,border-color .15s ease,transform .15s ease}.g-card:hover{border-color:#c7e0f4;box-shadow:var(--shadow-md);transform:translateY(-2px)}.g-thumb-link{display:block;text-decoration:none;position:relative}.g-thumb{position:relative;aspect-ratio:16 / 10;overflow:hidden;background:#eef2f8}.g-thumb-cover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.g-thumb-initial{font-size:44px;font-weight:800;color:#ffffffeb;text-shadow:0 2px 10px rgba(0,0,0,.2);letter-spacing:-1px}.g-thumb-frame{position:absolute;top:0;left:0;width:300%;height:300%;border:0;background:#fff;transform:scale(.3333);transform-origin:top left;pointer-events:none;animation:g-thumb-in .25s ease both}@keyframes g-thumb-in{0%{opacity:0}to{opacity:1}}.g-thumb-shimmer{position:absolute;inset:0;background:linear-gradient(100deg,#fff0 30%,#ffffff8c,#fff0 70%);background-size:220% 100%;animation:g-shimmer 1.2s linear infinite}@keyframes g-shimmer{0%{background-position:220% 0}to{background-position:-220% 0}}.g-badge{position:absolute;top:8px;left:8px;display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;color:#fff;background:#11203399;backdrop-filter:blur(4px)}.g-ver{position:absolute;left:8px;bottom:8px;padding:2px 8px;border-radius:999px;background:#11203399;color:#fff;font-size:11px;font-weight:700;backdrop-filter:blur(4px)}.g-del{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow-sm);font-size:14px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s ease,background .12s ease}.g-card:hover .g-del,.g-del:focus-visible{opacity:1}.g-del:hover{background:#fdf3f4}.g-meta{display:flex;flex-direction:column;gap:6px;padding:12px 14px 14px}.g-name{font-size:14px;font-weight:600;color:var(--fg);text-decoration:none;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.g-name:hover{color:var(--brand)}.g-sub{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--fg-2)}.g-owner{max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.g-sub-dot{opacity:.5}.g-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.g-tags-more{font-size:11px;color:var(--fg-2);align-self:center}.gallery-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:44px 24px}.gallery-empty-art{color:var(--brand);opacity:.85;margin-bottom:4px}.gallery-empty h3{margin:0;font-size:18px;color:var(--fg)}.gallery-empty p{margin:0;max-width:440px;font-size:14px;color:var(--fg-2)}.gallery-empty p code{font-size:12px;background:#eef2f8;border-radius:4px;padding:1px 5px}.gallery-empty .primary-btn,.gallery-empty .secondary-btn{margin-top:8px;gap:6px}.auth-layout{align-content:center}.auth-page{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:24px;background:radial-gradient(1100px 600px at 12% -10%,rgba(15,108,189,.18),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(118,184,255,.16),transparent 55%),linear-gradient(180deg,#f6f9fd,#eef3f9);box-sizing:border-box}.auth-shell{display:grid;grid-template-columns:1.05fr 1fr;width:100%;max-width:1080px;min-height:560px;background:var(--surface);border-radius:20px;box-shadow:0 30px 80px #0d2f592e,0 2px 6px #0d2f590f;overflow:hidden;border:1px solid rgba(15,108,189,.08)}.auth-hero{position:relative;padding:48px;color:#fff;background:radial-gradient(620px 380px at 0% 0%,rgba(255,255,255,.16),transparent 60%),radial-gradient(420px 280px at 100% 100%,rgba(255,255,255,.1),transparent 65%),linear-gradient(155deg,#0a4f8e,#0f6cbd 55%,#1882d4);display:flex;flex-direction:column;gap:40px;overflow:hidden}.auth-hero:before,.auth-hero:after{content:"";position:absolute;border-radius:50%;background:#ffffff14;pointer-events:none}.auth-hero:before{width:320px;height:320px;right:-100px;top:-100px}.auth-hero:after{width:220px;height:220px;left:-80px;bottom:-80px}.auth-hero>*{position:relative;z-index:1}.auth-hero-brand{display:flex;align-items:center;gap:12px}.auth-hero-logo{width:40px;height:40px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.18))}.auth-hero-brand-name{font-size:18px;font-weight:600;letter-spacing:.2px}.auth-hero-tagline h2{margin:0 0 14px;font-size:30px;line-height:1.18;font-weight:600;letter-spacing:-.4px}.auth-hero-tagline p{margin:0;font-size:14.5px;line-height:1.55;color:#ffffffdb;max-width:380px}.auth-hero-features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}.auth-hero-features li{display:flex;align-items:flex-start;gap:12px}.auth-hero-feature-icon{flex:0 0 36px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:10px;font-size:17px;backdrop-filter:blur(4px)}.auth-hero-feature-title{font-size:14px;font-weight:600;margin-bottom:2px}.auth-hero-feature-body{font-size:13px;line-height:1.5;color:#ffffffc7}.auth-card{padding:56px 56px 40px;display:flex;flex-direction:column;justify-content:center}.auth-card-brand{display:none;align-items:center;gap:10px;margin-bottom:28px}.auth-card-logo{width:36px;height:36px}.auth-card-brand-name{font-size:18px;font-weight:600;color:var(--fg)}.auth-card-title{margin:0 0 10px;font-size:26px;font-weight:600;color:var(--fg);letter-spacing:-.2px}.auth-card-subtitle{margin:0 0 28px;font-size:14px;line-height:1.55;color:var(--fg-2)}.auth-provider-list{display:flex;flex-direction:column;gap:10px}.auth-provider-btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:12px 18px;width:100%;background:#fff;color:var(--fg);border:1px solid var(--stroke);border-radius:10px;font-size:14.5px;font-weight:600;text-decoration:none;transition:border-color .12s ease,transform 80ms ease,box-shadow .12s ease,background .12s ease;box-shadow:0 1px 2px #0000000f}.auth-provider-btn:hover{border-color:var(--brand);box-shadow:0 6px 16px #0f6cbd29}.auth-provider-btn:active{transform:translateY(1px);box-shadow:0 1px 3px #0000001f}.auth-provider-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.provider-logo{width:18px;height:18px;flex:0 0 18px}.auth-card-foot{margin:24px 0 0;font-size:12px;line-height:1.5;color:var(--fg-2);text-align:center}@media(max-width:880px){.auth-shell{grid-template-columns:1fr;min-height:0;max-width:440px}.auth-hero{display:none}.auth-card{padding:40px 32px 32px}.auth-card-brand{display:flex}}.primary-btn,.secondary-btn{border-radius:6px;border:1px solid transparent;padding:8px 12px;font-weight:600;font-size:13px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-family:inherit}.primary-btn{background:var(--brand);border-color:var(--brand);color:#fff}.primary-btn:hover:not(:disabled){background:var(--brand-hover);border-color:var(--brand-hover)}.primary-btn:disabled,.secondary-btn:disabled{cursor:not-allowed;opacity:.6}.secondary-btn{background:#fff;border-color:var(--stroke);color:var(--fg)}.secondary-btn:hover:not(:disabled){background:#f5f5f5}.danger-btn{background:var(--danger);border-color:var(--danger);color:#fff;border-radius:6px;border-style:solid;border-width:1px;padding:8px 12px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}.danger-btn:hover:not(:disabled){background:#a4262c;border-color:#a4262c}.danger-btn:disabled{cursor:not-allowed;opacity:.6}.icon-btn{background:none;border:1px solid transparent;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:14px;line-height:1}.icon-btn:hover:not(:disabled){background:#f0f0f0;border-color:var(--stroke-subtle)}.icon-btn.danger:hover:not(:disabled){background:#fdf3f4;border-color:#f5c6cb}.row-actions{text-align:right;width:40px}.search-row{display:flex;gap:8px}.search-row input[type=search]{flex:1;padding:8px 12px;border:1px solid var(--stroke);border-radius:6px;font-family:inherit;font-size:13px}.upload-card{display:flex;flex-direction:column;gap:14px}.upload-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.upload-card-head h2{margin:0 0 2px;font-size:16px;color:var(--fg)}.upload-card-subtitle{margin:0;font-size:13px}.upload-card-subtitle code{background:#eff6fc;border:1px solid #d4e6f7;border-radius:4px;padding:0 5px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:#0f548c}.upload-form{display:flex;flex-direction:column;gap:8px}.dropzone{position:relative;border:2px dashed #c7d6e6;border-radius:14px;background:linear-gradient(180deg,#f9fbff,#fff);padding:36px 20px;text-align:center;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease,box-shadow .18s ease;outline:none}.dropzone:hover:not(.is-uploading):not(.has-file){border-color:#93c5fd;background:linear-gradient(180deg,#f3f8ff,#fff)}.dropzone:focus-visible{border-color:var(--brand);box-shadow:0 0 0 3px #0f6cbd2e}.dropzone.is-dragging{border-color:var(--brand);border-style:solid;background:linear-gradient(180deg,#e6f1fc,#fff);transform:scale(1.005);box-shadow:0 8px 24px #0f6cbd2e}.dropzone.has-file{border-style:solid;border-color:#d4e6f7;background:var(--surface);cursor:default;padding:18px 20px}.dropzone.is-uploading{cursor:progress;opacity:.85}.dropzone-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none}.dropzone-prompt{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e6f1fc,#f3f8ff);color:var(--brand);margin-bottom:4px;transition:background .18s ease,color .18s ease,transform .18s ease}.dropzone.is-dragging .dropzone-icon{background:var(--brand);color:#fff;transform:translateY(-2px)}.dropzone-title{font-size:15px;font-weight:600;color:var(--fg)}.dropzone-hint{font-size:13px;color:var(--fg-2)}.dropzone-link{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}.dropzone-meta{margin-top:4px;font-size:11px;color:#8a8a8a;letter-spacing:.04em;text-transform:uppercase}.dropzone-file{display:flex;align-items:center;gap:14px;text-align:left}.dropzone-file-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#eff6fc;font-size:22px;flex-shrink:0}.dropzone-file-meta{flex:1;min-width:0}.dropzone-file-name{font-weight:600;font-size:14px;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropzone-file-size{font-size:12px;color:var(--fg-2);margin-top:2px}.dropzone-file-actions{display:flex;gap:8px;flex-shrink:0}.dropzone-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;display:inline-block;margin-right:8px;vertical-align:-2px;animation:dropzone-spin .8s linear infinite}@keyframes dropzone-spin{to{transform:rotate(360deg)}}@media(max-width:640px){.dropzone{padding:28px 16px}.dropzone-file{flex-direction:column;align-items:stretch;text-align:center}.dropzone-file-actions{justify-content:center}}.files-table{width:100%;border-collapse:collapse;margin-top:12px}.files-table th,.files-table td{text-align:left;border-bottom:1px solid var(--stroke-subtle);padding:8px 4px}.files-table a{text-decoration:none;font-weight:500}.files-table a:hover{text-decoration:underline}.pagination-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}.pagination-summary{color:var(--fg-2);font-size:12px}.pagination-controls{display:flex;align-items:center;gap:6px}.pagination-controls .secondary-btn{padding:4px 10px;min-width:32px}.pagination-page{font-size:12px;color:var(--fg-2);padding:0 6px}.muted{color:var(--fg-2)}.error-text{margin:0;padding:8px 12px;border:1px solid #f5c6cb;border-radius:6px;background:#fff2f1;color:var(--danger)}.info-text{margin:0;padding:8px 12px;border:1px solid #c7e0f4;border-radius:6px;background:#eff6fc;color:#0f548c;font-size:13px}.toast{position:fixed;top:16px;right:16px;z-index:1000;display:inline-flex;align-items:center;gap:10px;min-width:220px;max-width:360px;padding:10px 12px 10px 14px;border-radius:var(--radius);box-shadow:var(--shadow-md);font-size:14px;color:#fff;animation:toast-slide-in .18s ease-out}.toast-success{background:#107c10}.toast-error{background:var(--danger)}.toast-info{background:var(--brand)}.toast-message{flex:1}.toast-dismiss{flex:0 0 auto;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:4px;background:#ffffff2e;color:inherit;font-size:16px;line-height:1;cursor:pointer}.toast-dismiss:hover{background:#ffffff52}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.spec-error{flex:1 1 auto;min-height:60vh;display:flex;align-items:center;justify-content:center;padding:48px 24px;--error-accent: var(--brand);--error-accent-soft: rgba(15, 108, 189, .12)}.spec-error-warning{--error-accent: #b86e00;--error-accent-soft: rgba(184, 110, 0, .12)}.spec-error-danger{--error-accent: var(--danger);--error-accent-soft: rgba(197, 15, 31, .12)}.spec-error-neutral{--error-accent: #5a5a5a;--error-accent-soft: rgba(90, 90, 90, .12)}.spec-error-card{width:100%;max-width:520px;padding:40px 36px 32px;background:var(--surface);border:1px solid var(--stroke-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;animation:spec-error-rise .28s cubic-bezier(.2,.8,.25,1)}@keyframes spec-error-rise{0%{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.spec-error-icon{width:96px;height:96px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--error-accent-soft);color:var(--error-accent)}.spec-error-icon-svg{width:52px;height:52px;stroke:currentColor;fill:currentColor}.spec-error-eyebrow{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--error-accent);margin-bottom:10px}.spec-error-title{font-size:24px;font-weight:600;line-height:1.25;color:var(--fg);margin:0 0 12px}.spec-error-description{font-size:15px;line-height:1.55;color:var(--fg-2);margin:0 0 18px}.spec-error-detail{font-size:13px;color:var(--fg-2);background:var(--bg);border:1px solid var(--stroke-subtle);border-radius:var(--radius);padding:10px 12px;margin:0 0 18px;text-align:left}.spec-error-meta{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;margin:0 auto 24px;background:var(--bg);border:1px solid var(--stroke-subtle);border-radius:999px;font-size:12px}.spec-error-meta-label{color:var(--fg-2);font-weight:500}.spec-error-meta-value{color:var(--fg);font-family:ui-monospace,Cascadia Mono,Consolas,monospace;font-size:12px;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spec-error-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}@media(max-width:480px){.spec-error-card{padding:28px 22px}.spec-error-title{font-size:20px}.spec-error-icon{width:80px;height:80px}.spec-error-icon-svg{width:44px;height:44px}}.section-title-row{display:flex;justify-content:space-between;align-items:center}.dialog-backdrop{position:fixed;inset:0;background:#00000052;display:flex;align-items:center;justify-content:center;padding:16px;z-index:350}.dialog{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--stroke-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px}.dialog h2{font-size:18px;font-weight:700;margin:0 0 8px}.dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.dialog.share-dialog{max-width:540px;max-height:calc(100vh - 48px);display:flex;flex-direction:column}.share-header{flex-shrink:0}.share-intro{margin:0 0 16px;font-size:13px;line-height:1.45}.share-create{display:flex;flex-direction:column;gap:14px;padding:16px;background:#faf9f8;border:1px solid var(--stroke-subtle);border-radius:var(--radius)}.share-create-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.share-field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--fg-2)}.share-field-optional{font-weight:400;color:var(--fg-2)}.share-create select,.share-create input[type=text]{width:100%;padding:9px 10px;font-size:13px;font-weight:400;color:var(--fg);background:#fff;border:1px solid var(--stroke);border-radius:6px;font-family:inherit}.share-create select:focus,.share-create input[type=text]:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px #0f6cbd2e}.share-create-btn{align-self:flex-start;padding:9px 20px}.share-links{display:flex;flex-direction:column;gap:10px;margin-top:18px;overflow-y:auto}.share-links-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-2)}.share-empty{font-size:13px;margin:0;padding:16px;text-align:center;border:1px dashed var(--stroke);border-radius:var(--radius)}.share-link-item{display:flex;flex-direction:column;gap:10px;padding:12px 14px;border:1px solid var(--stroke-subtle);border-radius:var(--radius);background:#fff}.share-link-item.is-new{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand),var(--shadow-sm);background:#f6fbff}.share-link-head{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.share-link-perm{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600}.share-link-perm.perm-view{background:#eff6fc;color:#0f548c}.share-link-perm.perm-comment{background:#e9f7ef;color:#0e6f3f}.share-link-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:500;background:#f3f2f1;color:var(--fg-2)}.share-link-expiry{margin-left:auto;font-size:12px;color:var(--fg-2);white-space:nowrap}.share-link-hint{margin:0;font-size:12px;color:#0f548c}.share-link-copy{display:flex;gap:8px}.share-link-url{flex:1;min-width:0;padding:8px 10px;font-size:12px;font-family:Cascadia Code,Consolas,ui-monospace,monospace;color:var(--fg);background:#faf9f8;border:1px solid var(--stroke);border-radius:6px}.share-copy-btn{flex-shrink:0;padding:8px 16px}.share-link-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.share-action{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;font-size:12px;font-weight:600;color:var(--fg);text-decoration:none;border:1px solid var(--stroke);border-radius:6px;background:#fff}.share-action:hover{background:#f5f5f5}.share-link-note{font-size:12px;color:var(--fg-2);font-style:italic}.share-revoke{margin-left:auto;border:none;background:transparent;color:var(--danger);font-size:12px;font-weight:600;cursor:pointer;padding:5px 10px;border-radius:6px;font-family:inherit}.share-revoke:hover{background:#fdf3f4}@media(max-width:420px){.share-create-grid{grid-template-columns:1fr}}.share-viewer{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg)}.share-viewer-bar{flex-shrink:0;height:52px;display:flex;align-items:center;gap:12px;padding:0 16px;background:linear-gradient(135deg,#0a4f8e,#0f6cbd,#2a8be0);box-shadow:0 2px 8px #0f6cbd2e;color:#fff}.share-viewer-title{flex:1;min-width:0;font-weight:600;font-size:14px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-viewer-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.share-viewer-actions .secondary-btn{background:#ffffff29;border-color:#ffffff73;color:#fff}.share-viewer-actions .secondary-btn:hover{background:#ffffff47}.share-viewer-frame{flex:1;min-height:0;width:100%;border:0;background:#fff}.share-viewer-message{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px;text-align:center}.share-viewer-message h1{margin:0;font-size:22px;font-weight:700}.share-viewer-message .muted{margin:0;font-size:14px;max-width:380px}.share-passcode-form{display:flex;gap:8px;margin-top:4px}.share-passcode-form input{min-width:200px;padding:9px 12px;font-size:14px;border:1px solid var(--stroke);border-radius:6px;font-family:inherit}.share-passcode-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px #0f6cbd2e}.privacy-options{display:flex;flex-direction:column;gap:8px;margin:12px 0}.privacy-option{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--fg);cursor:pointer}.privacy-option input[type=radio]{margin-top:2px}.privacy-scoped{margin-top:8px;margin-bottom:12px}.privacy-scoped-caption{font-size:12px;font-weight:600;color:var(--fg-2);margin-bottom:6px}.user-tags{display:flex;flex-wrap:wrap;gap:6px;min-height:24px;margin-bottom:8px}.user-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 6px 3px 10px;border-radius:12px;background:#eff6fc;color:#0f548c;font-size:12px;font-weight:500}.user-tag button{border:none;background:transparent;color:inherit;cursor:pointer;font-size:14px;line-height:1;padding:0 4px}.tag-empty-hint{font-size:12px;color:var(--fg-2);font-style:italic}.tag-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tag-suggestion{border:1px dashed var(--stroke);background:var(--surface);color:var(--fg-2);border-radius:12px;padding:3px 10px;font-size:12px;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.tag-suggestion:hover{background:#eff6fc;color:#0f548c;border-color:#c7e0f4}.tag-filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:4px 0 12px}.tag-filter-label{font-size:12px;font-weight:600;color:var(--fg-2);margin-right:2px}.tag-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;border:1px solid var(--stroke-subtle);background:var(--surface);color:var(--fg);font-size:12px;cursor:pointer;transition:background .1s,border-color .1s,color .1s}.tag-chip:hover{background:#f3f8fd;border-color:#c7e0f4}.tag-chip.active{background:var(--brand);border-color:var(--brand);color:#fff}.tag-chip-count{font-size:10px;font-weight:700;opacity:.7}.tag-chip-x{font-size:13px;line-height:1}.tag-filter-clear{border:none;background:transparent;color:var(--brand);font-size:12px;cursor:pointer;padding:3px 6px}.tag-filter-clear:hover{text-decoration:underline}.row-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.row-tag{border:1px solid var(--stroke-subtle);background:#f6f8fa;color:var(--fg-2);border-radius:10px;padding:1px 8px;font-size:11px;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.row-tag:hover{background:#eff6fc;color:#0f548c;border-color:#c7e0f4}.row-tag.active{background:var(--brand);border-color:var(--brand);color:#fff}.scoped-input-row{display:flex;gap:8px}.scoped-input-row input{flex:1;padding:6px 10px;border:1px solid var(--stroke);border-radius:6px;font-family:inherit;font-size:13px}.share-row{display:flex;gap:8px;margin:12px 0}.share-row input{flex:1;padding:6px 10px;border:1px solid var(--stroke);border-radius:6px;font-family:inherit;font-size:13px;background:#fafafa}.primary-nav{display:flex;align-items:center;gap:6px}.nav-link{background:transparent;border:1px solid transparent;border-radius:6px;padding:6px 14px;font-size:14px;font-family:inherit;font-weight:600;color:#ffffffd9;cursor:pointer;transition:background .12s,color .12s}.nav-link:hover{background:#ffffff29;color:#fff}.nav-link.active{background:#ffffff38;color:#fff}.dashboard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.dashboard-title{margin:0;font-size:22px}.dashboard-subtitle{margin:4px 0 0;font-size:13px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}.kpi-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--stroke-subtle);border-radius:var(--radius-lg);background:linear-gradient(135deg,#f0f7ff,#fff 70%);box-shadow:var(--shadow-sm)}.kpi-icon{font-size:26px;line-height:1}.kpi-value{font-size:26px;font-weight:700;color:var(--fg);line-height:1.1}.kpi-label{font-size:12px;color:var(--fg-2);text-transform:uppercase;letter-spacing:.03em}.dashboard-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:12px}.visibility-filter{display:flex;gap:6px}.bulk-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 14px;margin-bottom:12px;border:1px solid var(--brand);border-radius:var(--radius);background:#eff6fc}.bulk-count{font-weight:600;font-size:13px;margin-right:4px}.link-btn{background:none;border:none;color:var(--brand);font-family:inherit;font-size:13px;cursor:pointer;padding:6px 8px}.link-btn:hover:not(:disabled){text-decoration:underline}.files-table .select-col{width:36px;text-align:center}.files-table tr.row-selected{background:#eff6fc}.landing{flex:1 1 auto;min-height:0;overflow-y:auto;scroll-behavior:smooth;scroll-padding-top:72px;background:radial-gradient(1100px 620px at 8% -8%,rgba(15,108,189,.14),transparent 60%),radial-gradient(900px 560px at 108% 4%,rgba(92,45,145,.12),transparent 55%),linear-gradient(180deg,#fff,#f5f8fc);color:var(--fg)}.lp-nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:24px;padding:14px 32px;background:#ffffffd1;backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid rgba(15,108,189,.1)}.lp-brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--fg)}.lp-brand-logo{width:30px;height:30px}.lp-brand-name{font-size:17px;font-weight:700;letter-spacing:-.2px}.lp-nav-links{display:flex;gap:22px;margin-left:12px}.lp-nav-links a{text-decoration:none;color:var(--fg-2);font-size:14px;font-weight:500}.lp-nav-links a:hover{color:var(--fg)}.lp-nav-cta{margin-left:auto;display:flex;align-items:center;gap:14px}.lp-signin-link{text-decoration:none;color:var(--fg);font-size:14px;font-weight:600}.lp-signin-link:hover{color:var(--brand)}.lp-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;font-weight:600;font-size:14px;text-decoration:none;padding:9px 16px;cursor:pointer;transition:transform 80ms ease,box-shadow .14s ease,background .14s ease,border-color .14s ease;border:1px solid transparent}.lp-btn-primary{background:linear-gradient(135deg,#0f6cbd,#2a8be0);color:#fff;box-shadow:0 6px 18px #0f6cbd47}.lp-btn-primary:hover{box-shadow:0 10px 26px #0f6cbd57;transform:translateY(-1px)}.lp-btn-ghost{background:#fff;color:var(--fg);border-color:var(--stroke)}.lp-btn-ghost:hover{border-color:var(--brand);color:var(--brand)}.lp-btn-lg{padding:13px 24px;font-size:15px;border-radius:12px}.lp-btn:focus-visible,.lp-signin-link:focus-visible,.lp-brand:focus-visible,.lp-nav-links a:focus-visible{outline:3px solid var(--brand);outline-offset:3px;border-radius:10px}.lp-btn-primary:focus-visible{outline-color:#14223b}.lp-main{width:100%}.lp-hero,.lp-features,.lp-how,.lp-cta{max-width:1120px;margin:0 auto;padding:0 32px;box-sizing:border-box}.lp-hero{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center;padding-top:72px;padding-bottom:72px}.lp-hero-copy,.lp-hero-art{min-width:0}.lp-eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);background:#0f6cbd1a;padding:5px 12px;border-radius:999px;margin-bottom:18px}.lp-hero-title{margin:0 0 18px;font-size:48px;line-height:1.06;font-weight:800;letter-spacing:-1.4px;color:#14223b}.lp-grad{background:linear-gradient(120deg,#0f6cbd,#2a8be0 45%,#5c2d91);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.lp-hero-sub{margin:0 0 28px;font-size:17px;line-height:1.6;color:var(--fg-2);max-width:520px}.lp-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.lp-trust{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:18px}.lp-trust li{position:relative;padding-left:22px;font-size:13.5px;color:var(--fg-2);font-weight:500}.lp-trust li:before{content:"\2713";position:absolute;left:0;top:-1px;color:#0e8a4f;font-weight:800}.lp-hero-art{position:relative}.lp-window{max-width:100%;border-radius:14px;background:#fff;border:1px solid rgba(13,47,89,.1);box-shadow:0 30px 70px #0d2f5933,0 4px 12px #0d2f5914;overflow:hidden;transform:perspective(1400px) rotateY(-6deg) rotateX(2deg)}.lp-window-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f3f5f9;border-bottom:1px solid rgba(13,47,89,.08)}.lp-window-dot{width:10px;height:10px;border-radius:50%;background:#d2d6dd}.lp-window-dot:nth-child(1){background:#ff6058}.lp-window-dot:nth-child(2){background:#ffbe2f}.lp-window-dot:nth-child(3){background:#2aca44}.lp-window-url{flex:1;min-width:0;margin:0 8px;display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid rgba(13,47,89,.1);border-radius:7px;padding:5px 10px;font-size:11.5px;color:var(--fg-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lp-window-lock{font-size:10px}.lp-window-share{flex-shrink:0;font-size:11.5px;font-weight:600;color:#fff;background:var(--brand);border-radius:7px;padding:5px 10px}.lp-window-body{position:relative;padding:26px 28px 32px;background:radial-gradient(520px 240px at 80% -10%,rgba(15,108,189,.06),transparent 60%),#fff;min-height:280px}.bd-body{min-height:312px;overflow:hidden}.bd-prompt{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid rgba(13,47,89,.12);border-radius:10px;background:#f7f9fc;font-size:13px;font-weight:500;color:#14223b}.bd-prompt-spark{color:var(--brand);font-size:13px;flex-shrink:0}.bd-typing{overflow:hidden;white-space:nowrap}.bd-typed{display:inline-block;clip-path:inset(0 100% 0 0);animation:bd-type 10s steps(36) infinite}.bd-caret{width:2px;height:15px;background:var(--brand);border-radius:1px;flex-shrink:0;animation:bd-caret 10s steps(1,end) infinite}.bd-building{position:absolute;left:0;right:0;top:168px;display:flex;align-items:center;justify-content:center;gap:7px;font-size:12px;font-weight:600;color:var(--brand);opacity:0;animation:bd-building 10s ease infinite}.bd-building-dot{width:7px;height:7px;border-radius:50%;background:var(--brand)}.bd-dash{margin-top:12px}.bd-el{opacity:0}.bd-dash-head{display:flex;align-items:center;margin-bottom:12px;animation:bd-fade 10s ease infinite}.bd-dash-title{font-size:17px;font-weight:800;letter-spacing:-.3px;color:#14223b}.bd-live{display:inline-flex;align-items:center;gap:5px;margin-left:auto;font-size:11.5px;font-weight:700;color:#0e8a4f}.bd-live-dot{width:7px;height:7px;border-radius:50%;background:#18b85f;animation:bd-live-dot 10s ease infinite}.bd-kpis{display:flex;gap:10px;margin-bottom:14px}.bd-kpi{flex:1;border:1px solid rgba(13,47,89,.1);border-radius:10px;padding:9px 11px;background:#fff}.bd-k1{animation:bd-kpi-1 10s ease infinite}.bd-k2{animation:bd-kpi-2 10s ease infinite}.bd-k3{animation:bd-kpi-3 10s ease infinite}.bd-kpi-k{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-2);font-weight:600}.bd-kpi-v{display:block;font-size:18px;font-weight:800;color:#14223b;margin-top:2px}.bd-kpi-trend{display:block;font-size:10.5px;font-weight:700;color:#0e8a4f;margin-top:1px}.bd-chart{position:relative;height:116px;border:1px solid rgba(13,47,89,.08);border-radius:10px;padding:10px 12px;background:linear-gradient(180deg,#fbfdff,#f3f8fd);overflow:hidden;animation:bd-fade 10s ease infinite}.bd-grid{position:absolute;inset:12px 12px 18px;display:flex;flex-direction:column;justify-content:space-between}.bd-grid span{height:1px;background:#0d2f590f}.bd-bars{position:absolute;inset:14px 12px 16px;display:flex;align-items:flex-end;gap:8px}.bd-bar{flex:1;height:var(--bh);border-radius:4px 4px 0 0;background:linear-gradient(180deg,#2a8be0,#0f6cbd);transform:scaleY(0);transform-origin:bottom}.bd-bar-1{animation:bd-bar-1 10s ease infinite}.bd-bar-2{animation:bd-bar-2 10s ease infinite}.bd-bar-3{animation:bd-bar-3 10s ease infinite}.bd-bar-4{animation:bd-bar-4 10s ease infinite}.bd-bar-5{animation:bd-bar-5 10s ease infinite}.bd-bar-6{animation:bd-bar-6 10s ease infinite}.bd-line{position:absolute;inset:14px 12px 16px;overflow:visible}.bd-area-path{opacity:0;animation:bd-area 10s ease infinite}.bd-line-path{stroke-dasharray:1;stroke-dashoffset:1;filter:drop-shadow(0 1px 2px rgba(92,45,145,.25));animation:bd-line 10s ease infinite}.bd-body *{animation-delay:-7.2s}.lp-ai-strip{margin:18px 0 0;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--fg-2)}.lp-ai-flow{font-weight:700;color:var(--brand);background:#0f6cbd14;padding:3px 10px;border-radius:999px}.lp-ai-sep{color:var(--stroke)}@keyframes bd-type{0%{clip-path:inset(0 100% 0 0)}18%{clip-path:inset(0 0 0 0)}90%{clip-path:inset(0 0 0 0)}96%,to{clip-path:inset(0 100% 0 0)}}@keyframes bd-caret{0%,3%{opacity:1}4%,7%{opacity:.1}8%,12%{opacity:1}13%,16%{opacity:.1}17%,18%{opacity:1}20%,to{opacity:0}}@keyframes bd-building{0%,18%{opacity:0;transform:translateY(4px)}22%,46%{opacity:1;transform:none}54%,to{opacity:0}}@keyframes bd-fade{0%,20%{opacity:0;transform:translateY(8px)}26%,86%{opacity:1;transform:none}92%,to{opacity:0;transform:translateY(8px)}}@keyframes bd-kpi-1{0%,22%{opacity:0;transform:translateY(8px)}28%,86%{opacity:1;transform:none}92%,to{opacity:0;transform:translateY(8px)}}@keyframes bd-kpi-2{0%,25%{opacity:0;transform:translateY(8px)}31%,86%{opacity:1;transform:none}92%,to{opacity:0;transform:translateY(8px)}}@keyframes bd-kpi-3{0%,28%{opacity:0;transform:translateY(8px)}34%,86%{opacity:1;transform:none}92%,to{opacity:0;transform:translateY(8px)}}@keyframes bd-bar-1{0%,30%{transform:scaleY(0)}38%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-bar-2{0%,33%{transform:scaleY(0)}41%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-bar-3{0%,36%{transform:scaleY(0)}44%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-bar-4{0%,39%{transform:scaleY(0)}47%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-bar-5{0%,42%{transform:scaleY(0)}50%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-bar-6{0%,45%{transform:scaleY(0)}53%,88%{transform:scaleY(1)}94%,to{transform:scaleY(0)}}@keyframes bd-line{0%,48%{stroke-dashoffset:1}66%,88%{stroke-dashoffset:0}94%,to{stroke-dashoffset:1}}@keyframes bd-area{0%,58%{opacity:0}70%,86%{opacity:1}92%,to{opacity:0}}@keyframes bd-live-dot{0%,66%{transform:scale(1);opacity:1}70%{transform:scale(1.6);opacity:.65}74%{transform:scale(1);opacity:1}78%{transform:scale(1.6);opacity:.65}82%,to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.bd-typed{clip-path:none!important;animation:none!important}.bd-caret,.bd-building{display:none!important}.bd-el{opacity:1!important;transform:none!important;animation:none!important}.bd-bar{transform:scaleY(1)!important;animation:none!important}.bd-area-path{opacity:1!important;animation:none!important}.bd-line-path{stroke-dashoffset:0!important;animation:none!important}.bd-live-dot,.g-thumb-frame,.g-thumb-shimmer{animation:none!important}.g-card{transition:none!important}}.lp-section-head{text-align:center;max-width:640px;margin:0 auto 40px}.lp-section-head h2{margin:0 0 10px;font-size:32px;font-weight:800;letter-spacing:-.8px;color:#14223b}.lp-section-head p{margin:0;font-size:16px;color:var(--fg-2)}.lp-features{padding-top:40px;padding-bottom:40px}.lp-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.lp-feature{background:#fff;border:1px solid rgba(13,47,89,.08);border-radius:16px;padding:26px 24px;box-shadow:0 1px 3px #0d2f590d;transition:transform .14s ease,box-shadow .14s ease}.lp-feature:hover{transform:translateY(-3px);box-shadow:0 16px 40px #0d2f591f}.lp-feature-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:linear-gradient(135deg,#0f6cbd1f,#5c2d911f);margin-bottom:16px}.lp-feature h3{margin:0 0 8px;font-size:18px;font-weight:700;color:#14223b}.lp-feature p{margin:0;font-size:14px;line-height:1.55;color:var(--fg-2)}.lp-how{padding-top:48px;padding-bottom:48px}.lp-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}.lp-step{display:flex;gap:14px;align-items:flex-start}.lp-step-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0f6cbd,#2a8be0);color:#fff;font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #0f6cbd47}.lp-step-body h3{margin:4px 0 6px;font-size:16px;font-weight:700;color:#14223b}.lp-step-body p{margin:0;font-size:14px;line-height:1.55;color:var(--fg-2)}.lp-cta{padding-top:40px;padding-bottom:80px}.lp-cta-card{max-width:460px;margin:0 auto;background:#fff;border:1px solid rgba(13,47,89,.08);border-radius:20px;padding:40px 40px 32px;text-align:center;box-shadow:0 24px 60px #0d2f5924}.lp-cta-card h2{margin:0 0 8px;font-size:24px;font-weight:800;letter-spacing:-.4px;color:#14223b}.lp-cta-card>p{margin:0 0 24px;font-size:14px;color:var(--fg-2)}.lp-cta-card .auth-provider-list{text-align:left}.lp-cta-open{width:100%;margin-top:4px}.lp-cta-foot{margin:20px 0 0;font-size:12px;line-height:1.5;color:var(--fg-2)}.lp-footer{border-top:1px solid rgba(13,47,89,.08);background:#fff;padding:28px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.lp-footer-brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--fg)}.lp-footer-logo{width:24px;height:24px}.lp-footer-copy{margin:0;font-size:13px;color:var(--fg-2)}@media(max-width:900px){.lp-hero{grid-template-columns:1fr;gap:40px;padding-top:48px;padding-bottom:56px}.lp-hero-title{font-size:38px;letter-spacing:-1px}.lp-window{transform:none}.lp-feature-grid,.lp-steps{grid-template-columns:1fr}.lp-nav-links{display:none}}@media(max-width:540px){.lp-nav{padding:12px 18px}.lp-hero,.lp-features,.lp-how,.lp-cta{padding-left:18px;padding-right:18px}.lp-hero-title{font-size:32px}.lp-hero-actions{flex-direction:column;align-items:stretch}.lp-btn-lg{width:100%}.lp-cta-card{padding:32px 24px 24px}}
