:root{color:#1f2933;background:#f6f8fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;margin:0}button{min-height:2.25rem;font:inherit;cursor:pointer;border:1px solid #0000;border-radius:6px;padding:.45rem .85rem}button:disabled{cursor:not-allowed;opacity:.6}[hidden]{display:none!important}.btn-primary,button.btn-primary{color:#fff;background:#238655;border-color:#1f6f46;align-items:center;gap:.5rem;display:inline-flex}.btn-primary:hover:not(:disabled){background:#1f6f46}.btn-secondary,button.btn-secondary{color:#2d3a4a;background:#fff;border-color:#c5cfdb}.btn-secondary:hover:not(:disabled){background:#f1f4f9}.app-shell{width:min(960px,100vw - 2rem);margin:0 auto;padding:3rem 0}.toolbar{border-bottom:1px solid #d9e2ec;justify-content:space-between;align-items:center;gap:2rem;padding-bottom:1.5rem;display:flex}h1{margin:0;font-size:2rem}h2{margin:0 0 1rem;font-size:1.1rem}p{color:#52616f;margin:.5rem 0 0}.app-icon{width:64px;height:64px}.actions{flex-wrap:wrap;gap:.75rem;margin:2rem 0;display:flex}.diagnostics{border-top:1px solid #d9e2ec;padding-top:1.5rem}dl{gap:.75rem;margin:0;display:grid}dl div{grid-template-columns:minmax(10rem,14rem) 1fr;gap:1rem;display:grid}dt{color:#52616f}dd{margin:0;font-weight:600}.status{color:#334e68;min-height:1.5rem}.status[data-kind=success]{color:#1f6f46}.status[data-kind=warning]{color:#9a5b00}.status[data-kind=error]{color:#b42318}.editor-shell{background:#fff;grid-template-rows:auto minmax(0,1fr);height:100vh;display:grid}.editor-toolbar{background:#fff;border-bottom:1px solid #d9e2ec;align-items:center;gap:1rem;padding:.55rem 1rem;display:flex}.editor-title{color:#1f2933;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;margin:0;font-size:1rem;font-weight:600;overflow:hidden}.editor-status{color:#52616f;text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;margin:0;font-size:.85rem;overflow:hidden}.editor-status:empty{visibility:hidden}.editor-status[data-kind=success]{color:#1f6f46}.editor-status[data-kind=warning]{color:#9a5b00}.editor-status[data-kind=error]{color:#b42318}.editor-title__separator{color:#94a3b8;margin:0 .25rem}.editor-title__filename{color:#475569;font-weight:500}.editor-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.editor-actions .drive-icon{flex-shrink:0;width:18px;height:18px}.editor-host{min-height:0}.editor-frame{border:0;width:100%;height:100%;display:block}.saving-modal{z-index:9999;background:#0f172a8c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.saving-modal--visible{display:flex}.saving-modal__card{text-align:center;background:#fff;border-radius:10px;min-width:280px;max-width:420px;padding:1.75rem 2rem;box-shadow:0 20px 50px #0f172a40}.saving-modal__spinner{border:3px solid #d9e2ec;border-top-color:#238655;border-radius:50%;width:36px;height:36px;margin:0 auto 1rem;animation:.9s linear infinite saving-modal-spin}.saving-modal--error .saving-modal__spinner{display:none}.saving-modal__title{color:#1f2933;margin:0 0 .4rem;font-size:1.05rem;font-weight:600}.saving-modal__hint{color:#52616f;margin:0;font-size:.9rem}.saving-modal--error .saving-modal__title{color:#b42318}.saving-modal__close{color:#2d3a4a;cursor:pointer;background:#fff;border:1px solid #c5cfdb;border-radius:6px;margin-top:1rem;padding:.4rem .85rem}@keyframes saving-modal-spin{to{transform:rotate(360deg)}}@media (width<=640px){.toolbar,dl div{grid-template-columns:1fr}.toolbar{align-items:flex-start}.editor-toolbar{flex-wrap:wrap}.editor-title{flex-basis:100%}}.landing-page{--teal:#2bb9b0;--teal-dark:#1f9b93;--teal-soft:#e6f6f5;--orange:#f59147;--ink:#1f1f1f;--ink-2:#444746;--ink-3:#5f6368;--line:#e3e3e3;--bg:#fff;--bg-soft:#f8f9fa;--gdrive-blue:#1a73e8;--gdrive-blue-soft:#e8f0fe;--gdrive-green:#34a853;--gdrive-yellow:#fbbc04;--shadow-card:0 1px 2px 0 #3c40431a, 0 1px 3px 1px #3c40430d;--shadow-hover:0 1px 3px 0 #3c404326, 0 4px 8px 3px #3c404314;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:Google Sans,Roboto,system-ui,-apple-system,sans-serif;line-height:1.5}.landing-page a{color:var(--gdrive-blue);text-decoration:none}.landing-page a:hover{text-decoration:underline}.landing-page .nav{border-bottom:1px solid var(--line);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:12px 28px;display:flex;position:sticky;top:0}.landing-page .nav-left{align-items:center;gap:14px;display:flex}.landing-page .nav-logo{color:var(--ink);align-items:center;gap:10px;font-size:20px;font-weight:500;display:flex}.landing-page .nav-logo img{width:auto;height:30px}.landing-page .nav-brand{letter-spacing:-.2px;font-weight:500}.landing-page .nav-pill{background:var(--teal-soft);color:var(--teal-dark);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.landing-page .nav-pill:before{content:"";background:var(--teal);border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #2bb9b02e}.landing-page .nav-right{color:var(--ink-2);align-items:center;gap:22px;font-size:14px;display:flex}.landing-page .nav-right a{color:var(--ink-2)}.landing-page .nav-right .cta{background:var(--gdrive-blue);color:#fff;border-radius:999px;padding:8px 20px;font-weight:500}.landing-page .nav-right .cta:hover{background:#1765cc;text-decoration:none}.landing-page .hero{grid-template-columns:1.05fr 1fr;align-items:center;gap:64px;max-width:1180px;margin:0 auto;padding:72px 28px 48px;display:grid}.landing-page .hero-eyebrow{color:var(--teal-dark);background:var(--teal-soft);border-radius:999px;align-items:center;gap:8px;margin-bottom:20px;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.landing-page .hero-eyebrow svg{width:16px;height:16px}.landing-page h1{letter-spacing:-1.2px;margin:0 0 20px;font-family:Google Sans,sans-serif;font-size:56px;font-weight:500;line-height:1.08}.landing-page h1 .accent{color:var(--teal)}.landing-page h1 .accent-orange{color:var(--orange)}.landing-page .hero-sub{color:var(--ink-3);max-width:520px;margin:0 0 32px;font-size:18px}.landing-page .hero-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.landing-page .btn{cursor:pointer;border:1px solid #0000;border-radius:999px;align-items:center;gap:10px;padding:12px 22px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.landing-page .btn-primary{background:var(--gdrive-blue);color:#fff}.landing-page .btn-primary:hover{box-shadow:var(--shadow-card);background:#1765cc;text-decoration:none}.landing-page .btn-ghost{color:var(--gdrive-blue);border-color:var(--line);background:#fff}.landing-page .btn-ghost:hover{background:var(--gdrive-blue-soft);text-decoration:none}.landing-page .btn svg{width:18px;height:18px}.landing-page .hero-meta{color:var(--ink-3);flex-wrap:wrap;gap:24px;margin-top:28px;font-size:13px;display:flex}.landing-page .hero-meta span{align-items:center;gap:6px;display:inline-flex}.landing-page .check{background:var(--gdrive-green);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;display:inline-flex}.landing-page .mock{border:1px solid var(--line);box-shadow:var(--shadow-hover);transform-origin:50%;background:#fff;border-radius:14px;overflow:hidden;transform:perspective(1200px)rotateY(-4deg)rotateX(2deg)}.landing-page .mock-bar{border-bottom:1px solid var(--line);background:#fafbfc;align-items:center;gap:8px;padding:10px 14px;display:flex}.landing-page .mock-bar .dot{background:#e8eaed;border-radius:50%;width:10px;height:10px}.landing-page .mock-bar .url{border:1px solid var(--line);color:var(--ink-3);background:#fff;border-radius:999px;flex:1;padding:4px 12px;font-family:Roboto,sans-serif;font-size:12px}.landing-page .mock-body{padding:18px}.landing-page .mock-section-title{color:var(--ink-2);margin:0 0 12px;font-size:13px;font-weight:500}.landing-page .mock-files{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.landing-page .mock-file{border:1px solid var(--line);background:#fff;border-radius:10px;flex-direction:column;gap:10px;padding:14px;transition:all .15s;display:flex;position:relative}.landing-page .mock-file:hover{box-shadow:var(--shadow-card);border-color:#d0d7de}.landing-page .mock-file.highlight{border-color:var(--teal);box-shadow:0 0 0 3px #2bb9b026}.landing-page .mock-file-thumb{background:linear-gradient(135deg,#f1f8f7 0%,#e6f6f5 100%);border-radius:6px;justify-content:center;align-items:center;height:78px;display:flex}.landing-page .mock-file-thumb img{width:auto;height:44px}.landing-page .mock-file-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;font-size:12.5px;font-weight:500;display:flex;overflow:hidden}.landing-page .mock-file-name .exetag{background:var(--teal);color:#fff;letter-spacing:.3px;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.landing-page .mock-file-meta{color:var(--ink-3);font-size:11px}.landing-page .action-section{padding:56px 28px 72px}.landing-page .action-card{background:linear-gradient(135deg, #fff 0%, var(--teal-soft) 100%);border:1px solid var(--line);max-width:880px;box-shadow:var(--shadow-card);border-radius:20px;margin:0 auto;padding:32px}.landing-page .action-card-head{align-items:center;gap:10px;margin-bottom:16px;display:flex}.landing-page .action-card-head img{height:28px}.landing-page .action-card-title{font-size:16px;font-weight:500}.landing-page .action-card hr{border:0;border-top:1px solid var(--line);margin:0 -32px 20px}.landing-page .action-flow{grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;gap:14px;display:grid}.landing-page .action-divider{background:var(--line);align-self:stretch;width:1px;margin:6px 4px}.landing-page .action-or{border:1px solid var(--line);width:32px;height:32px;color:var(--ink-3);letter-spacing:.5px;text-transform:uppercase;background:#fff;border-radius:50%;justify-content:center;align-self:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.landing-page .action-btn{border:1px solid var(--line);cursor:pointer;min-height:0;color:var(--ink-2);background:#fff;border-radius:999px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 14px;font-family:inherit;font-size:13.5px;font-weight:500;transition:all .15s;display:inline-flex}.landing-page .action-btn:hover{background:var(--bg-soft)}.landing-page .action-btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}.landing-page .action-btn.primary:hover{background:#000}.landing-page .action-btn.success{background:var(--gdrive-green);color:#fff;border-color:var(--gdrive-green)}.landing-page .action-btn.success:hover{background:#2e8b46}.landing-page .action-btn.disabled,.landing-page .action-btn[disabled],.landing-page .action-btn[aria-disabled=true]{color:#9aa0a6;cursor:not-allowed;opacity:1}.landing-page .action-btn.disabled:hover,.landing-page .action-btn[disabled]:hover,.landing-page .action-btn[aria-disabled=true]:hover{background:#fff}.landing-page .diagnostics{color:var(--ink-3);margin-top:16px;font-size:12.5px}.landing-page .diag-row{border-bottom:1px dashed var(--line);justify-content:space-between;padding:6px 0;display:flex}.landing-page .diag-row:last-child{border-bottom:0}.landing-page .diag-row strong{color:var(--ink-2);font-weight:500}.landing-page .diag-ok{color:var(--gdrive-green);font-weight:500}.landing-page .diag-warn{color:#9a5b00;font-weight:500}.landing-page .diag-error{color:#b42318;font-weight:500}.landing-page .landing-footer{border-top:1px solid var(--line);max-width:1180px;color:var(--ink-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;margin:0 auto;padding:32px 28px;font-size:13px;display:flex}.landing-page .landing-footer .foot-left{align-items:center;gap:10px;display:flex}.landing-page .landing-footer .foot-left img{width:auto;height:28px;display:block}.landing-page .landing-footer .foot-left:hover{text-decoration:none}.landing-page .landing-footer nav{gap:22px;display:flex}.landing-page .landing-footer nav a{color:var(--ink-3)}@media (width<=900px){.landing-page .hero{grid-template-columns:1fr;gap:40px;padding-top:48px}.landing-page .mock{transform:none}.landing-page h1{font-size:40px}.landing-page .nav-right{gap:14px}.landing-page .nav-right a:not(.cta){display:none}}@media (width<=640px){.landing-page .action-card{padding:24px}.landing-page .action-card hr{margin:0 -24px 18px}.landing-page .action-flow{grid-template-columns:1fr;gap:10px}.landing-page .action-divider{width:100%;height:1px;margin:4px 0}.landing-page .action-or{justify-self:center}}
