:root{--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--touch-min: 44px;--color-primary: #646cff;--color-primary-hover: #535ac8;--color-primary-bg: rgba(100, 108, 255, .08);--color-danger: #d32f2f;--color-danger-hover: #c62828;--color-danger-bg: #fef2f2;--color-warning: #f57c00;--color-warning-bg: #fff8e1;--color-success: #2e7d32;--color-success-bg: #f0fdf4;--color-text: #1a1a1a;--color-text-secondary: #666;--color-text-muted: #999;--color-bg: #fafafa;--color-bg-white: #fff;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 20px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .15);--shadow-xl: 0 10px 40px rgba(0, 0, 0, .2);--z-header: 100;--z-drawer-overlay: 900;--z-drawer: 950;--z-modal: 1000;--max-width: 1400px;--header-height: auto;--container-padding: 2rem}@media(min-width:1024px)and (max-width:1365px){:root{--container-padding: 1.25rem}}@media(max-width:1023px){:root{--container-padding: 1rem}}.form-group input:not([type=checkbox]):not([type=radio]):not([type=file]),.form-group select,.filter-group select,.filter-group input,.search-input{box-sizing:border-box;height:2.75rem;font-size:.875rem;padding:.5rem .75rem}.form-group textarea{box-sizing:border-box}@media(max-width:1365px){.responsive-table{display:block;box-shadow:none!important;background:transparent!important;border-radius:0;overflow:visible}.responsive-table thead{display:none}.responsive-table tbody{display:flex;flex-direction:column;gap:var(--space-md)}.responsive-table tbody tr{display:flex;flex-direction:column;background:var(--color-bg-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);padding:var(--space-md);gap:var(--space-xs)}.responsive-table tbody tr.inactive-row{opacity:.65}.responsive-table tbody td{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-xs) 0;border:none;font-size:.9rem}.responsive-table tbody td:before{content:attr(data-label);font-weight:600;color:var(--color-text-secondary);font-size:.8rem;min-width:110px;flex-shrink:0;padding-top:2px}.responsive-table tbody td:first-child{padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-xs)}.responsive-table tbody td:first-child:before{display:none}.responsive-table tbody td:first-child strong,.responsive-table tbody td:first-child .user-info strong{font-size:1rem}.responsive-table tbody td:last-child{border-top:1px solid var(--color-border-light);padding-top:var(--space-sm);margin-top:var(--space-xs)}.responsive-table tbody td:last-child:before{display:none}.responsive-table tbody td:last-child .actions,.responsive-table tbody td.actions:last-child,.responsive-table tbody td.check-actions:last-child{display:flex;flex-wrap:wrap;gap:var(--space-xs);width:100%}.responsive-table tbody td:last-child .actions button,.responsive-table tbody td:last-child .actions .btn-small,.responsive-table tbody td:last-child .actions .icon-btn,.responsive-table tbody td.actions:last-child button,.responsive-table tbody td.actions:last-child .btn-small,.responsive-table tbody td.actions:last-child .icon-btn,.responsive-table tbody td.check-actions:last-child button,.responsive-table tbody td.check-actions:last-child .btn-small,.responsive-table tbody td.check-actions:last-child .icon-btn{flex:1 1 0;min-height:var(--touch-min);font-size:.85rem;text-align:center;justify-content:center}}@media(min-width:1024px)and (max-width:1365px){.responsive-table tbody{display:grid;grid-template-columns:repeat(2,1fr)}}@media(max-width:1023px){.filters{flex-direction:column!important;gap:var(--space-sm)!important}.filters .filter-group{width:100%}.filters .filter-group select,.filters .filter-group input{width:100%;min-height:var(--touch-min);font-size:16px}}@media(max-width:1023px){.modal-overlay{align-items:stretch!important;padding:0!important}.modal,.modal-small,.modal-content{width:100%!important;max-width:100%!important;min-height:100vh!important;max-height:100vh!important;border-radius:0!important;display:flex!important;flex-direction:column!important;padding-bottom:0!important}.modal:has(>form),.modal-small:has(>form),.modal-content:has(>form){overflow:hidden!important}.modal>form,.modal-small>form,.modal-content>form{flex:1 1 0%!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;min-height:0!important;padding-bottom:0!important}.modal:not(:has(>form)),.modal-small:not(:has(>form)),.modal-content:not(:has(>form)){overflow-y:auto!important}.modal>h3,.modal>.modal-header,.modal-small>h3,.modal-small>.modal-header,.modal-content>h3,.modal-content>.modal-header{flex-shrink:0}.modal .form-actions,.modal-small .form-actions,.modal-content .form-actions,.modal .modal-actions,.modal-small .modal-actions,.modal-content .modal-actions{position:sticky;bottom:0;z-index:10;flex-shrink:0;background:var(--color-bg-white);padding:var(--space-md) var(--space-lg);padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #00000014;margin:0}.modal .form-actions>button:only-child,.modal .modal-actions>button:only-child{width:100%}}@media(max-width:1023px){.form-grid{grid-template-columns:1fr!important}}@media(max-width:1023px){button,.btn-primary,.btn-secondary,.btn-small,.btn-danger,.btn-warning{min-height:var(--touch-min)}input:not([type=checkbox]):not([type=radio]),select,textarea{min-height:var(--touch-min);font-size:16px}}@media(max-width:1023px){.header{flex-direction:column!important;align-items:stretch!important;gap:var(--space-sm)!important}.header h2{font-size:1.25rem}.header-actions{display:flex;gap:var(--space-sm)}.header-actions button,.header-actions .btn-primary{flex:1;min-height:var(--touch-min)}}.form-group input[type=checkbox],.form-group input[type=radio],input[type=checkbox],input[type=radio]{width:18px;height:18px;padding:0;border:none;border-radius:0;box-shadow:none;accent-color:#646cff;cursor:pointer;flex-shrink:0}.form-group:has(input[type=checkbox]),.form-group:has(input[type=radio]){grid-column:1 / -1}.form-group:has(input[type=checkbox])>label,.form-group:has(input[type=radio])>label{display:flex;align-items:center;gap:.5rem;margin-bottom:0;cursor:pointer;font-weight:400}.header-actions .btn-primary,.template-manager-header .btn-primary{padding:.6rem 1.2rem;font-size:.95rem;border-radius:6px}.table-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-md));padding:0 var(--space-md)}@media(max-width:1023px){.summary{font-size:.85rem;text-align:center;flex-wrap:wrap}}.modal:has(>.modal-header),.modal-content:has(>.modal-header){padding-top:0}@supports (padding: env(safe-area-inset-top)){.app-header{padding-top:env(safe-area-inset-top)}.app-footer{padding-bottom:env(safe-area-inset-bottom)}.mobile-drawer{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}}@media(min-width:1024px)and (max-width:1365px){.recent-completions-table th,.recent-completions-table td{padding:.5rem .6rem;font-size:.85rem}.filter-group,.handover-protocol-list .filter-group,.template-manager .filter-group{min-width:160px}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.details-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}}.responsive-table th:last-child{width:1%;white-space:nowrap}.actions{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;justify-content:flex-end}.actions:has(>:only-child){justify-content:center}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-white);color:var(--color-text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.icon-btn:hover{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.icon-btn--danger:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.icon-btn--warning:hover{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.icon-btn--success{color:var(--color-success)}.icon-btn--success:hover{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.icon-btn--info:hover{background:#2196f314;border-color:#2196f3;color:#2196f3}.icon-btn--filled{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.icon-btn--filled:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.icon-btn-label{display:none}@media(max-width:1365px){.responsive-table tbody td:last-child .actions .icon-btn,.responsive-table tbody td.check-actions:last-child .icon-btn{width:auto;flex:1 1 0;min-height:var(--touch-min);gap:6px;padding:0 12px;font-size:.8rem;font-weight:500}.responsive-table tbody td:last-child .actions .icon-btn .icon-btn-label,.responsive-table tbody td.check-actions:last-child .icon-btn .icon-btn-label{display:inline}.responsive-table tbody td:last-child .actions .icon-btn--danger{color:var(--color-danger);border-color:var(--color-danger)}.responsive-table tbody td:last-child .actions .icon-btn--warning{color:var(--color-warning);border-color:var(--color-warning)}.responsive-table tbody td:last-child .actions .icon-btn--info{color:#2196f3;border-color:#2196f3}.responsive-table tbody td:last-child .actions .icon-btn--filled{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.responsive-table tbody td:last-child .actions .icon-btn--success{color:var(--color-success);border-color:var(--color-success)}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;position:relative}.login-back-arrow{position:absolute;top:24px;left:24px;background:none;border:none;cursor:pointer;color:#fffc;font-size:28px;line-height:1;padding:8px 12px;border-radius:8px;transition:background .2s,color .2s}.login-back-arrow:hover{color:#fff;background:#ffffff26}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:420px}.login-box h1{margin:0 0 8px;font-size:28px;color:#333;text-align:center}.login-subtitle{margin:0 0 32px;font-size:14px;color:#666;text-align:center}.login-error{background-color:#fee;color:#c33;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group input::placeholder{color:#999}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;margin:20px 0;gap:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#ddd}.login-divider span{font-size:13px;color:#999;text-transform:uppercase;letter-spacing:.5px}.sso-button{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#333;border:1px solid #ddd;font-weight:500;margin-top:0}.sso-button:hover:not(:disabled){background:#f8f8f8;border-color:#bbb;box-shadow:0 2px 8px #0000001a}.google-sso-button{margin-top:8px}.login-footer{margin-top:24px;text-align:center}.login-footer p{margin:0;font-size:13px;color:#666}.back-to-landing{background:none;border:none;cursor:pointer;color:#fffc;font-size:15px;font-weight:500;margin-top:16px;padding:0;font-family:inherit;transition:color .2s}.back-to-landing:hover{color:#fff}.register-row{display:flex;gap:12px}.register-row .form-group{flex:1}.register-link{background:none;border:none;cursor:pointer;color:#667eea;font-size:13px;font-weight:600;padding:0;font-family:inherit;text-decoration:underline}.register-link:hover{color:#764ba2}@media(max-width:480px){.login-box{padding:32px 24px}.login-box h1{font-size:24px}.register-row{flex-direction:column;gap:0}}.hamburger,.mobile-drawer,.drawer-overlay{display:none}@media(max-width:1023px){.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:var(--touch-min);height:var(--touch-min);padding:10px;background:none;border:none;cursor:pointer}.hamburger__line{display:block;width:24px;height:2px;background:var(--color-text);border-radius:2px}.drawer-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:var(--z-drawer-overlay);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-drawer{display:flex;position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:var(--color-bg-white);z-index:var(--z-drawer);transform:translate(-100%);transition:transform .3s ease;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-drawer--open{transform:translate(0)}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-lg) var(--space-md);background:var(--color-primary);color:#fff}.drawer-user strong{display:block;font-size:1.1rem;margin-bottom:var(--space-xs)}.drawer-role{font-size:.85rem;opacity:.85}.drawer-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border:none;border-radius:var(--radius-sm);color:#fff;font-size:1.1rem;cursor:pointer;flex-shrink:0;transition:background .15s}.drawer-close:hover,.drawer-close:active{background:#ffffff4d}.drawer-nav{list-style:none;margin:0;padding:var(--space-sm) 0;flex:1}.drawer-nav li{margin:0}.drawer-nav-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md);border:none;background:none;font-size:.95rem;color:var(--color-text);cursor:pointer;text-align:left;min-height:var(--touch-min);transition:background .15s}.drawer-nav-item:hover,.drawer-nav-item:active{background:var(--color-border-light)}.drawer-nav-item--active{background:var(--color-primary-bg);color:var(--color-primary);font-weight:600;border-right:3px solid var(--color-primary)}.drawer-nav-icon{font-size:1.2rem;width:28px;text-align:center;flex-shrink:0}.drawer-footer{padding:var(--space-md);border-top:1px solid var(--color-border)}.drawer-logout{width:100%;padding:var(--space-md);background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:500;cursor:pointer;min-height:var(--touch-min);transition:background .2s}.drawer-logout:hover,.drawer-logout:active{background:var(--color-danger-hover)}}.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch}.pricing-card{background:#fff;border:2px solid #e8e8ef;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.pricing-card.popular{border-color:#667eea;box-shadow:0 4px 20px #667eea26}.pricing-card.current{border-color:#28a745}.popular-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:6px 0;display:flex;align-items:center;justify-content:center;gap:6px}.current-badge{background:#28a745;color:#fff;text-align:center;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:6px 0}.placeholder-badge{background:#f0f0f5;text-align:center;font-size:12px;font-weight:700;padding:6px 0}.card-header{padding:24px 20px 20px;text-align:center;border-bottom:1px solid #f0f0f5}.card-header h3{margin:0 0 6px;font-size:20px;color:#1a1a2e}.plan-description{margin:0 0 16px;font-size:13px;color:#888;line-height:1.4;min-height:36px}.price{display:flex;align-items:baseline;justify-content:center;gap:2px;min-height:44px}.price .amount{font-size:36px;font-weight:800;color:#1a1a2e}.price .currency{font-size:14px;color:#888;font-weight:500}.free-price{font-size:28px;font-weight:700;color:#28a745}.custom-price{font-size:28px;font-weight:700;color:#667eea}.card-features{padding:16px 20px;flex:1}.feature-section{margin-bottom:14px}.feature-section:last-child{margin-bottom:0}.feature-section h4{margin:0 0 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#aaa}.feature-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:13px;height:24px}.feature-label{color:#555}.feature-value{font-weight:600;color:#1a1a2e}.feature-bool{display:flex;align-items:center;gap:6px;padding:2px 0;font-size:13px;height:24px}.feature-bool.enabled{color:#28a745}.feature-bool.disabled{color:#ccc}.feature-bool.disabled span{text-decoration:line-through;color:#bbb}.card-action{padding:16px 20px 20px;margin-top:auto}.plan-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.plan-btn .spin{animation:pricingSpin 1s linear infinite}@keyframes pricingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upgrade-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.upgrade-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.upgrade-btn:disabled{opacity:.6;cursor:not-allowed}.current-btn{background:#f0f0f0;color:#888;cursor:default}.enterprise-btn{background:#1a1a2e;color:#fff}.enterprise-btn:hover{background:#2a2a4e}.downgrade-btn{background:#f8f8f8;color:#aaa;border:1px solid #eee;cursor:not-allowed}@media(max-width:1024px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.pricing-grid{grid-template-columns:1fr}}.landing-page{min-height:100vh;background:#fff;color:#1a1a2e}.landing-nav{position:sticky;top:0;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #e8e8ef}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.landing-logo{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;font-size:1.1rem;font-weight:700;color:#1a1a2e;padding:0}.landing-logo svg{color:#646cff}.landing-nav-links{display:flex;gap:.25rem}.landing-nav-links button{background:none;border:none;cursor:pointer;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#555;border-radius:6px;transition:all .2s;min-width:100px;text-align:center}.landing-nav-links button:hover{color:#1a1a2e;background:#f5f5f8}.landing-nav-actions{display:flex;align-items:center;gap:.75rem}.lang-switch{display:flex;background:#f0f0f5;border-radius:6px;overflow:hidden}.lang-switch button{background:none;border:none;cursor:pointer;padding:6px 10px;font-size:.75rem;font-weight:600;color:#888;transition:all .2s}.lang-switch button.active{background:#646cff;color:#fff}.nav-login-btn{background:none;border:none;cursor:pointer;font-size:.9rem;font-weight:500;color:#555;padding:.5rem .75rem;transition:color .2s;min-width:90px;text-align:center}.nav-login-btn:hover{color:#1a1a2e}.nav-cta-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:8px;transition:all .2s;min-width:155px;text-align:center}.nav-cta-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.landing-hero{background:linear-gradient(135deg,#667eea,#764ba2,#5a67d8);background-size:400% 400%;animation:gradientShift 15s ease infinite;color:#fff;padding:6rem 2rem 8rem;text-align:center;position:relative;overflow:hidden}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero-particles span{position:absolute;display:block;border-radius:50%;background:#ffffff59;box-shadow:0 0 6px 2px #ffffff26;animation:floatUp linear infinite}.hero-particles span:nth-child(1){width:3px;height:3px;left:8%;bottom:-10px;animation-duration:22s;animation-delay:0s}.hero-particles span:nth-child(2){width:2px;height:2px;left:18%;bottom:-10px;animation-duration:28s;animation-delay:3s}.hero-particles span:nth-child(3){width:4px;height:4px;left:30%;bottom:-10px;animation-duration:20s;animation-delay:1s}.hero-particles span:nth-child(4){width:2px;height:2px;left:42%;bottom:-10px;animation-duration:26s;animation-delay:5s}.hero-particles span:nth-child(5){width:3px;height:3px;left:55%;bottom:-10px;animation-duration:24s;animation-delay:2s}.hero-particles span:nth-child(6){width:2px;height:2px;left:65%;bottom:-10px;animation-duration:30s;animation-delay:4s}.hero-particles span:nth-child(7){width:4px;height:4px;left:75%;bottom:-10px;animation-duration:21s;animation-delay:0s}.hero-particles span:nth-child(8){width:2px;height:2px;left:85%;bottom:-10px;animation-duration:27s;animation-delay:6s}.hero-particles span:nth-child(9){width:3px;height:3px;left:92%;bottom:-10px;animation-duration:23s;animation-delay:1s}.hero-particles span:nth-child(10){width:2px;height:2px;left:3%;bottom:-10px;animation-duration:25s;animation-delay:7s}.hero-particles span:nth-child(11){width:3px;height:3px;left:48%;bottom:-10px;animation-duration:29s;animation-delay:3s}.hero-particles span:nth-child(12){width:2px;height:2px;left:38%;bottom:-10px;animation-duration:22s;animation-delay:8s}@keyframes floatUp{0%{transform:translateY(0) translate(0);opacity:0}5%{opacity:.8}50%{opacity:.3}85%{opacity:.6}to{transform:translateY(-110vh) translate(30px);opacity:0}}.hero-wave{position:absolute;bottom:0;left:0;width:100%;line-height:0}.hero-wave svg{display:block;width:100%;height:60px}.hero-content{max-width:720px;margin:0 auto;position:relative;z-index:1}.landing-hero h1{font-size:3rem;font-weight:800;line-height:1.15;margin:0 0 .75rem;letter-spacing:-.5px}.hero-subtitle{font-size:1.5rem;font-weight:300;opacity:.9;margin:0 0 1.5rem}.hero-description{font-size:1.1rem;line-height:1.7;opacity:.85;margin:0 0 2.5rem}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.hero-cta-primary{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#667eea;border:none;cursor:pointer;padding:1rem 2rem;font-size:1.1rem;font-weight:700;border-radius:12px;transition:all .2s;box-shadow:0 4px 16px #00000026;position:relative;overflow:hidden}.hero-cta-primary:after{content:"";position:absolute;top:-50%;left:-75%;width:50%;height:200%;background:linear-gradient(90deg,transparent 0%,rgba(102,126,234,.12) 50%,transparent 100%);transform:skew(-20deg);animation:shimmer 4s ease-in-out infinite;animation-delay:2s}@keyframes shimmer{0%,to{left:-75%}50%{left:125%}}.hero-cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.hero-cta-secondary{display:inline-flex;align-items:center;gap:8px;background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.4);cursor:pointer;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;transition:all .2s}.hero-cta-secondary:hover{background:#ffffff40;border-color:#fff9}.landing-section{padding:5rem 2rem}.landing-section-alt{background:#f8f9fc}.section-inner{max-width:1200px;margin:0 auto}.section-narrow{max-width:800px}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{font-size:2.25rem;font-weight:800;margin:0 0 .75rem;color:#1a1a2e}.section-header p{font-size:1.1rem;color:#666;margin:0}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature-card{background:#fff;border:1px solid #e8e8ef;border-radius:12px;padding:2rem;transition:all .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014;border-color:#d0d0e0}.feature-icon{width:56px;height:56px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#667eea;margin-bottom:1.25rem}.feature-card h3{font-size:1.15rem;font-weight:700;margin:0 0 .5rem;color:#1a1a2e}.feature-card p{font-size:.9rem;line-height:1.6;color:#666;margin:0}.landing-cta-btn{background:#fff;color:#555;border:2px solid #e8e8ef}.landing-cta-btn:hover{background:#f5f5f8;border-color:#ccc}.faq-list{display:flex;flex-direction:column;gap:0}.faq-item{border-bottom:1px solid #e8e8ef}.faq-item:first-child{border-top:1px solid #e8e8ef}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 0;background:none;border:none;cursor:pointer;text-align:left;font-size:1rem;font-weight:600;color:#1a1a2e;transition:color .2s}.faq-question:hover{color:#667eea}.faq-chevron{flex-shrink:0;transition:transform .3s;color:#888}.faq-item.open .faq-chevron{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}.faq-item.open .faq-answer{max-height:300px}.faq-answer p{margin:0 0 1.25rem;font-size:.95rem;line-height:1.7;color:#555}.landing-cta{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:5rem 2rem;text-align:center}.cta-content{max-width:600px;margin:0 auto}.landing-cta h2{font-size:2rem;font-weight:800;margin:0 0 .75rem}.landing-cta p{font-size:1.1rem;opacity:.85;margin:0 0 2rem}.landing-footer{background:#1a1a2e;color:#aab;padding:3rem 2rem 1.5rem}.landing-footer-inner{max-width:1200px;margin:0 auto}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2rem}.footer-logo{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:#fff;margin-bottom:.75rem}.footer-logo svg{color:#667eea}.footer-description{font-size:.85rem;line-height:1.6;margin:0;max-width:300px}.footer-links-group h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#ddd;margin:0 0 1rem}.footer-links-group button{display:block;background:none;border:none;cursor:pointer;padding:4px 0;font-size:.85rem;color:#aab;transition:color .2s;text-align:left}.footer-links-group button:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;text-align:center}.footer-bottom p{font-size:.8rem;margin:0;color:#778}@media(max-width:1023px){.landing-nav-links,.nav-login-btn{display:none}.landing-hero{padding:4rem 1.5rem 6rem}.hero-wave svg{height:40px}.landing-hero h1{font-size:2.25rem}.hero-subtitle{font-size:1.25rem}.hero-description{font-size:1rem}.landing-section{padding:3.5rem 1.5rem}.section-header h2{font-size:1.75rem}.features-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.footer-brand{grid-column:1 / -1}}@media(max-width:640px){.landing-nav-inner{padding:0 1rem}.landing-logo span{display:none}.landing-hero{padding:3rem 1rem 5rem}.hero-wave svg{height:30px}.landing-hero h1{font-size:1.75rem}.hero-subtitle{font-size:1.1rem}.hero-description{font-size:.9rem}.hero-actions{flex-direction:column;align-items:stretch}.hero-cta-primary,.hero-cta-secondary{justify-content:center;padding:.875rem 1.5rem;font-size:1rem}.landing-section{padding:2.5rem 1rem}.section-header h2{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.landing-cta{padding:3rem 1rem}.landing-cta h2{font-size:1.5rem}.footer-grid{grid-template-columns:1fr;gap:1.5rem}.landing-footer{padding:2rem 1rem 1rem}}.legal-page{padding:2rem;background:#f8f9fc;min-height:calc(100vh - 64px)}.legal-inner{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;padding:3rem;box-shadow:0 2px 8px #0000000f}.legal-back{background:none;border:none;cursor:pointer;font-size:.9rem;color:#667eea;font-weight:500;padding:0;margin-bottom:1.5rem;display:inline-block;transition:color .2s}.legal-back:hover{color:#764ba2}.legal-inner h1{font-size:2rem;font-weight:800;color:#1a1a2e;margin:0 0 2rem;padding-bottom:1rem;border-bottom:2px solid #e8e8ef}.legal-content h2{font-size:1.2rem;font-weight:700;color:#1a1a2e;margin:2rem 0 .75rem}.legal-content h2:first-child{margin-top:0}.legal-content p{font-size:.95rem;line-height:1.7;color:#444;margin:0 0 .75rem}.legal-content ul{padding-left:1.5rem;margin:.5rem 0 1rem}.legal-content li{font-size:.95rem;line-height:1.7;color:#444;padding:2px 0}.legal-content a{color:#667eea;text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-date{margin-top:2rem;color:#888;font-size:.85rem}@media(max-width:640px){.legal-page{padding:1rem}.legal-inner{padding:1.5rem}.legal-inner h1{font-size:1.5rem}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-drawer);background:var(--color-bg-white);border-top:1px solid var(--color-border);box-shadow:0 -4px 16px #0000001a;padding:var(--space-md) var(--space-lg);animation:cookie-slide-up .3s ease-out}@keyframes cookie-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-banner-content{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;gap:var(--space-md)}.cookie-banner-icon{flex-shrink:0;color:var(--color-primary)}.cookie-banner-text{flex:1;font-size:.875rem;line-height:1.5;color:var(--color-text)}.cookie-banner-text strong{display:block;margin-bottom:2px}.cookie-banner-text p{margin:0;color:var(--color-text-secondary)}.cookie-banner-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;font:inherit;text-decoration:underline}.cookie-banner-link:hover{color:var(--color-primary-hover)}.cookie-banner-actions{flex-shrink:0;display:flex;gap:var(--space-sm)}.cookie-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;border:none;transition:background-color .15s,color .15s}.cookie-btn-primary{background:var(--color-primary);color:#fff}.cookie-btn-primary:hover{background:var(--color-primary-hover)}.cookie-btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.cookie-btn-secondary:hover{background:var(--color-bg);color:var(--color-text)}@media(max-width:768px){.cookie-banner{padding:var(--space-md)}.cookie-banner-content{flex-direction:column;align-items:stretch;text-align:center}.cookie-banner-icon{display:none}.cookie-banner-actions{justify-content:center}}.app{min-height:100vh;display:flex;flex-direction:column;background:#fafafa}.app-header{background:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.app-header h1{margin:0;font-size:1.35rem;color:#1a1a1a;font-weight:700;display:flex;align-items:center;gap:.5rem}.app-logo-link{cursor:pointer;transition:opacity .2s}.app-logo-link:hover{opacity:.7}.nav button{padding:.5rem .85rem;border:none;background:transparent;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;flex-shrink:0}.nav button:hover{background:#f5f5f5;color:#1a1a1a}.nav button.active{background:#646cff;color:#fff}.app-main{flex:1;padding:2rem 0}.coming-soon{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.coming-soon h2{color:#1a1a1a;margin-bottom:1rem}.coming-soon p{color:#666;margin:.5rem 0}.coming-soon .hint{font-size:.95rem;color:#999}.app-footer{background:#fff;border-top:1px solid #e0e0e0;padding:1.5rem 2rem;text-align:center}.app-footer p{margin:0;color:#666;font-size:.9rem}.app-footer a{color:#646cff;text-decoration:none;font-weight:500}.app-footer a:hover{text-decoration:underline}.footer-link{background:none;border:none;cursor:pointer;color:#646cff;font-size:.9rem;font-weight:500;padding:0;font-family:inherit}.footer-link:hover{text-decoration:underline}.user-info{display:flex;flex-direction:row!important;align-items:center;gap:.75rem;flex-shrink:0;white-space:nowrap}.user-meta{font-size:.85rem;font-weight:500;color:#333}.user-role{display:inline-block;padding:.1rem .5rem;background:#eef;color:#646cff;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-left:.35rem;vertical-align:middle}.logout-button{padding:.3rem .65rem;background:none;color:#999;border:1px solid #ddd;border-radius:5px;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{color:#d32f2f;border-color:#d32f2f}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#fafafa}.app-loading p{color:#666;font-size:1.1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #646cff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.header-content{max-width:var(--max-width);margin:0 auto;padding:.75rem var(--container-padding);display:flex;justify-content:space-between;align-items:center;gap:1rem}.nav{display:flex;gap:.35rem;flex-wrap:nowrap;overflow-x:auto;padding:.5rem var(--container-padding);max-width:var(--max-width);margin:0 auto;border-top:1px solid #f0f0f0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav .nav-portal{margin-left:0}.app-trial-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:.88rem;font-weight:500;text-align:center}.app-trial-banner.trialing{background:#d1ecf1;color:#0c5460;border-bottom:1px solid #bee5eb}.app-trial-banner.expired{background:#fff3cd;color:#856404;border-bottom:1px solid #ffc107}.app-trial-banner .banner-cta{margin-left:12px;padding:4px 14px;border:none;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap}.app-trial-banner.trialing .banner-cta{background:#0c5460;color:#fff}.app-trial-banner.expired .banner-cta{background:#856404;color:#fff}.app-trial-banner .banner-cta:hover{opacity:.85}@media(max-width:1023px){.nav{display:none}.app-header h1{font-size:1.1rem;flex:1}.user-meta,.logout-button{display:none}.app-main{padding:1rem 0}.app-footer{padding:1rem var(--container-padding);font-size:.8rem}}
