@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.raterudder-header{background:var(--surface);border-bottom:1px solid var(--border);height:64px;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;width:100%}.header-inner{display:flex;justify-content:space-between;align-items:center;height:100%;padding-top:0;padding-bottom:0}.brand-logo{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:800;color:var(--text-primary);text-decoration:none;margin-right:2rem;letter-spacing:-.02em}.header-logo-img{height:32px;width:auto}.header-left{display:flex;align-items:center;flex:1}.site-selector-header{background:var(--surface-subtle);border:1px solid var(--border);color:var(--text-secondary);padding:.35rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s}.site-selector-header:hover{border-color:var(--border-focus)}.site-name-header{font-size:.85rem;color:var(--text-muted);margin-left:.5rem}.header-nav{flex:2;display:flex;justify-content:center;gap:.5rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:600;font-size:.9rem;padding:.5rem 1rem;border-radius:var(--radius-sm);transition:all .2s ease}.nav-link:hover{color:var(--primary);background:var(--surface-subtle)}.header-right{flex:1;display:flex;justify-content:flex-end;align-items:center}.login-link,.logout-link{color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:600;background:none;border:1px solid var(--border);padding:.4rem 1.25rem;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;transition:all .2s ease}.login-link:hover,.logout-link:hover{border-color:var(--primary);color:var(--primary);background:var(--surface-subtle)}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-around;width:26px;height:20px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger-line{width:100%;height:2px;background-color:var(--text-secondary);border-radius:2px;transition:all .2s ease}.header-content{display:contents}@media(max-width:768px){.raterudder-header{height:60px;z-index:1100}.header-inner{position:static}.brand-logo{margin-right:1rem;font-size:1.1rem}.header-left,.header-nav,.header-right{min-width:0}.mobile-menu-toggle{display:flex;margin-left:auto}.raterudder-header.logged-in .header-content{display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:1rem;box-shadow:var(--shadow-lg);z-index:1000}.raterudder-header.logged-in .header-content.open{display:flex}.header-nav{flex-direction:column;width:100%;margin-bottom:1rem}.header-right{justify-content:center;width:100%}.nav-link{text-align:center;width:100%;display:block;box-sizing:border-box}.logout-link,.login-link{width:100%;text-align:center;display:block}}.app-footer{margin-top:auto;padding:2rem 0 1.5rem;text-align:center;border-top:1px solid var(--border);color:var(--text-muted);font-size:.8rem}.footer-content{display:flex;flex-direction:column;gap:.4rem;align-items:center}.footer-links{display:flex;gap:.75rem;align-items:center}.footer-links a{color:var(--text-muted);text-decoration:none;transition:color .15s ease}.footer-links a:hover{color:var(--primary)}.separator{color:var(--border)}.opensource-link{margin-bottom:.25rem;color:var(--text-muted)}.opensource-link a{color:var(--text-muted);text-decoration:none;font-weight:600;transition:color .15s ease}.opensource-link a:hover{color:var(--primary)}.copyright{margin-top:.25rem;font-size:.75rem;color:var(--text-muted)}:root{--primary: #0ea5e9;--primary-hover: #0284c7;--accent: #10b981;--accent-hover: #059669;--warning: #f59e0b;--danger: #ef4444;--text-on-primary: #ffffff;--bg-app: #f8fafc;--surface: #ffffff;--surface-subtle: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border: #e2e8f0;--border-focus: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .025);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem}*{box-sizing:border-box}html,body{overflow-x:hidden;position:relative;width:100%}body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;background-color:var(--bg-app);color:var(--text-primary);line-height:1.5}.content-container{max-width:1000px;width:100%;margin:0 auto;padding:0 var(--spacing-sm)}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-container-home{display:flex;flex-direction:column;min-height:100vh;width:100%}.main-content{flex:1;padding-top:var(--spacing-md);padding-bottom:var(--spacing-xl)}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:50vh;color:var(--text-muted);font-weight:500}.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--spacing-md);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:var(--shadow-md)}button{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;transition:all .2s;cursor:pointer;border:none}.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--surface-subtle)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.action-list-container{display:flex;flex-direction:column;gap:var(--spacing-md)}.action-list-container .header{display:flex;justify-content:center;margin-bottom:var(--spacing-sm)}.date-controls{display:flex;align-items:center;gap:var(--spacing-md);background:var(--surface);padding:.5rem var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.date-controls h2{margin:0;font-size:1.125rem;font-weight:600;min-width:200px;text-align:center;color:var(--text-primary)}.date-controls button{background:transparent;border:none;color:var(--text-secondary);font-weight:500;cursor:pointer;padding:.5rem;border-radius:var(--radius-sm)}.date-controls button:hover:not(:disabled){color:var(--primary);background:var(--surface-subtle)}.date-controls button:disabled{opacity:.3;cursor:not-allowed}.savings-summary{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.savings-header{margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--border);padding-bottom:var(--spacing-xs)}.savings-header h3{margin:0;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:700}.savings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.savings-item{padding:var(--spacing-sm);background:var(--bg-app);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.25rem}.savings-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.savings-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.savings-value.positive{color:var(--accent)}.savings-value.negative{color:var(--danger)}.savings-value.neutral{color:var(--text-muted)}.savings-details{display:flex;flex-wrap:wrap;gap:var(--spacing-sm) var(--spacing-md);font-size:.875rem;color:var(--text-secondary);padding-top:var(--spacing-sm);border-top:1px dashed var(--border)}.action-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.action-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;gap:var(--spacing-md);transition:all .2s ease}.action-item:hover{border-color:var(--border-focus);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-time{font-family:Inter,monospace;font-variant-numeric:tabular-nums;font-size:.875rem;color:var(--text-muted);font-weight:500;min-width:80px;padding-top:.15rem}.action-details{flex:1}.action-details h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.action-details p{margin:0 0 .75rem;color:var(--text-secondary);font-size:.95rem;line-height:1.5}.tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:600;text-transform:capitalize}.mode-charge_any{background:#e0f2fe;color:#0369a1}.mode-charge_solar{background:#f0fdf4;color:#15803d}.mode-load{background:#ecfdf5;color:#047857}.mode-standby{background:#fffbeb;color:#b45309}.mode-no_change{background:#f1f5f9;color:#64748b}.solar-any{background:#fefce8;color:#a16207}.solar-no_export{background:#fff1f2;color:#be123c}.dry-run{background:#f3e8ff;color:#7e22ce}.tag-info{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.action-item.fault-item{border-left:4px solid var(--danger);background:#fef2f2}.fault-alarms{color:var(--danger);font-weight:600}.action-footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-muted);display:flex;gap:1rem}.price-label{font-weight:600;color:var(--text-secondary)}.no-actions{text-align:center;padding:var(--spacing-xl);color:var(--text-muted);font-style:italic;background:var(--surface);border-radius:var(--radius-lg);border:1px dashed var(--border)}.banner{display:flex;align-items:center;padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.95rem;line-height:1.5;border-left:4px solid transparent}.banner p{margin:0;display:flex;align-items:center;gap:.75rem}.warning-banner{background:#fffbeb;border:1px solid #fcd34d;border-left-color:#f59e0b;color:#92400e}.warning-banner p:before{content:"⚠️";font-size:1.25rem;margin-right:.25rem}.error{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem;text-align:center;border:1px solid #fecaca}@media(max-width:640px){.action-item{flex-direction:column;gap:.5rem}.action-time{font-size:.75rem}.savings-grid{grid-template-columns:1fr 1fr}}.landing-page{font-family:Inter,system-ui,-apple-system,sans-serif;color:#1e293b;line-height:1.6;background-color:#f8fafc;overflow-x:clip;width:100%}.content-container{max-width:1100px;width:100%;margin:0 auto;padding:0 1.5rem;position:relative;z-index:2}.content-container.hero-layout{display:flex;align-items:center;justify-content:space-between;gap:2rem}.content-container.features-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.hero-section{width:100%;padding:4rem 0;min-height:70vh;background:radial-gradient(circle at top right,#f0f9ff,#fff 45%,#ecfdf5);position:relative;display:flex;align-items:center;overflow:hidden}.badge{display:inline-block;padding:.5rem 1rem;background:#10b9811a;color:#059669;border-radius:99px;font-size:.875rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:.05em;text-transform:uppercase;border:1px solid rgba(16,185,129,.2)}.hero-content{flex:1.2;max-width:600px;padding-right:2rem}.hero-content h1{font-size:4rem;letter-spacing:-.04em;line-height:1;color:#0f172a;margin-bottom:1.5rem;margin-top:0;font-weight:900}.hero-content .highlight{background:linear-gradient(135deg,#0ea5e9,#10b981);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-content p{font-size:1.25rem;color:#475569;margin-bottom:2.5rem;max-width:520px;line-height:1.6}.cta-wrapper{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.cta-button{display:inline-block;padding:1.25rem 3rem;font-size:1.25rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:16px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 25px -5px #0f172a33;border:none;cursor:pointer}.cta-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 35px -10px #0f172a4d;background:linear-gradient(135deg,#1e293b,#334155)}.cta-note{font-size:.875rem;color:#94a3b8;margin-left:.5rem}.hero-visual{flex:.8;position:relative;display:flex;justify-content:center;align-items:center;height:450px}.marketing-disclaimer{font-size:.75rem;color:#94a3b8;max-width:800px;margin:2rem auto 0;text-align:center;line-height:1.6}@media(max-width:768px){.marketing-disclaimer{padding:0 1rem}}.pulse-circle{width:400px;height:400px;background:conic-gradient(from 180deg at 50% 50%,#d1fae5,#bae6fd,#d1fae5 360deg);border-radius:50%;position:relative;animation:spin-pulse 15s linear infinite;filter:blur(60px);opacity:.5}@keyframes spin-pulse{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.15)}to{transform:rotate(360deg) scale(1)}}.floating-card{position:absolute;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:2.5rem;border-radius:32px;box-shadow:0 40px 60px -15px #0000001a,0 0 0 1px #fff inset;display:flex;flex-direction:column;align-items:center;animation:float 8s ease-in-out infinite;z-index:10;border:1px solid rgba(226,232,240,.5)}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(1deg)}}.floating-card strong{font-size:4rem;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:900;line-height:1;margin:.5rem 0}.floating-card span{font-size:.875rem;text-transform:uppercase;color:#64748b;font-weight:700;letter-spacing:.15em}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#10b981;font-weight:600;margin-top:1.5rem;padding:.5rem 1rem;background:#ecfdf5;border-radius:99px}.status-indicator .dot{width:6px;height:6px;background:#10b981;border-radius:50%;box-shadow:0 0 8px #10b981}.features-strip{width:100%;padding:6rem 0;background:#fff;border-bottom:1px solid #f1f5f9}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem}.feature-item{display:flex;flex-direction:column;gap:1.25rem}.feature-item .icon{font-size:2rem;background:#f8fafc;width:4rem;height:4rem;display:flex;align-items:center;justify-content:center;border-radius:20px;border:1px solid #e2e8f0;transition:all .3s ease}.feature-item:hover .icon{transform:translateY(-5px) rotate(5deg);border-color:#0ea5e9;color:#0ea5e9;background:#f0f9ff}.feature-item h3{font-size:1.25rem;font-weight:800;color:#0f172a;margin:0}.feature-item p{font-size:1rem;color:#64748b;line-height:1.6;margin:0}.live-demo-section{width:100%;padding:4rem 0}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{font-size:2.5rem;color:#0f172a;margin-bottom:1rem;font-weight:800;letter-spacing:-.02em}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;width:100%}.chart-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000005,0 0 0 1px #e2e8f099;height:340px;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}.chart-card:hover{box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006,0 0 0 1px #e2e8f0cc}.chart-card.full-width{grid-column:span 2}.chart-card h3{font-size:.875rem;font-weight:700;color:#64748b;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem}.chart-card h3:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background:#cbd5e1}.chart-wrapper{flex:1;width:100%;min-height:0}.faq-section{width:100%;padding:6rem 0;background:transparent}.faq-container{display:flex;flex-direction:column;gap:1rem;max-width:800px;margin:0 auto}.faq-item{border:1px solid #e2e8f0;border-radius:12px;padding:0 1.5rem;transition:all .2s ease;background:#fff}.faq-item.active{border-color:#cbd5e1;background:#f8fafc}.faq-question{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:1.125rem;color:#334155;padding:1.25rem 0;transition:color .2s}.faq-question:hover{color:#0ea5e9}.toggle-icon{font-size:1.5rem;line-height:1;color:#94a3b8;background:#f1f5f9;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:transform .3s ease,background .3s ease}.faq-item.active .toggle-icon{background:#e0f2fe;color:#0284c7}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1);opacity:0}.faq-item.active .faq-answer{max-height:200px;opacity:1;padding-bottom:1.25rem;border-top:1px solid #e2e8f0;margin-top:-.5rem;padding-top:1rem}.faq-answer p{color:#64748b;margin:0;line-height:1.6}@media(max-width:768px){.content-container.hero-layout{flex-direction:column;gap:3rem;text-align:center;padding-top:2rem}.hero-content{padding-right:0;display:flex;flex-direction:column;align-items:center}.hero-content h1{font-size:2.75rem}.hero-content p{font-size:1.125rem}.cta-wrapper{align-items:center;width:100%}.cta-button{width:100%;padding:1.125rem 2rem;font-size:1.125rem}.hero-visual{height:350px;width:100%;margin-top:1rem}.pulse-circle{width:300px;height:300px}.floating-card{padding:2rem;border-radius:24px}.floating-card strong{font-size:3rem}.features-grid{grid-template-columns:1fr;gap:2.5rem}.feature-item{align-items:center;text-align:center}}.settings-container{max-width:600px;width:100%;margin:0 auto}.settings-container h2{font-size:1.875rem;font-weight:800;color:var(--text-primary);margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.settings-container h3{font-size:.875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:2.5rem;margin-bottom:1.25rem}.form-group{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.95rem;font-weight:600;color:var(--text-primary)}.form-group input[type=number],.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group select{width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;color:var(--text-primary);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0ea5e926}.form-group input:disabled{background:var(--surface-subtle);color:var(--text-muted);cursor:not-allowed;border-color:var(--border)}.checkbox-group{flex-direction:column;gap:.25rem}.checkbox-group label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:1rem}.checkbox-group input[type=checkbox]{width:1.25rem;height:1.25rem;border-radius:4px;accent-color:var(--primary);cursor:pointer}.help-text{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.error-message,.success-message,.warning-notice{padding:1rem;border-radius:var(--radius-md);font-size:.95rem;margin-bottom:1.5rem;display:flex;align-items:center}.error-message{background:#fef2f2;color:#ef4444;border:1px solid #fecaca}.success-message{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.warning-notice{background:#fffbeb;color:#b45309;border:1px solid #fde68a;margin-top:.5rem}.save-button{width:100%;margin-top:2rem;padding:1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.save-button:hover{background:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.save-button:active{transform:translateY(0)}details{border:1px solid var(--border);border-radius:var(--radius-md);padding:.5rem;margin-top:2rem;background:var(--surface-subtle)}details[open]{padding-bottom:1rem}summary{cursor:pointer;padding:.5rem;font-weight:600;color:var(--text-secondary);list-style:none;display:flex;align-items:center;justify-content:space-between}summary::-webkit-details-marker{display:none}summary:after{content:"▼";font-size:.75rem;transition:transform .2s}details[open] summary>span:after{transform:rotate(180deg)}details[open] summary:after{transform:rotate(180deg)}details h3{margin-top:1.5rem;padding-left:.5rem;border-bottom:1px solid var(--border);padding-bottom:.5rem;font-size:.8rem}details .form-group{padding:0 .5rem}.forecast-page h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.forecast-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem;margin-bottom:2rem}.forecast-charts{display:flex;flex-direction:column;gap:1.5rem}.forecast-chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin:0 0 1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}.forecast-chart-card:hover{box-shadow:var(--shadow-md)}.forecast-chart-card h3{font-size:.875rem;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin:0 0 1rem;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem}.forecast-chart-card h3:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--border-focus)}.forecast-loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-muted);font-style:italic;font-weight:500}.forecast-page .error{background:#fef2f2;color:#b91c1c;padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem;text-align:center}.forecast-page .no-actions{text-align:center;padding:3rem;background:var(--surface-subtle);border-radius:var(--radius-md);color:var(--text-muted)}@media(max-width:768px){.forecast-chart-card{padding:1rem .5rem}.forecast-charts{gap:1rem}.forecast-page h2{font-size:1.25rem}}.login-page{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{background:var(--surface);padding:3rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);text-align:center;width:100%;max-width:400px}.login-card h1{margin-bottom:.5rem;color:var(--text-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.login-card p{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.google-btn-wrapper{display:flex;justify-content:center;margin-bottom:1.5rem}.auth-disabled-message{color:var(--text-muted);font-size:.9rem;padding:1rem;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.login-footer{display:flex;justify-content:center;gap:.75rem;align-items:center;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-light)}.login-footer a{color:var(--text-muted);text-decoration:none;font-size:.8rem;transition:color .15s ease}.login-footer a:hover{color:var(--primary)}.login-footer .separator{color:var(--border)}.join-page{display:flex;justify-content:center;align-items:center;min-height:50vh}.join-card{background:var(--surface);padding:2.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);text-align:center;width:100%;max-width:420px}.join-card h1{margin-bottom:.5rem;color:var(--text-primary);font-size:1.5rem;font-weight:700}.join-card p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.join-form{display:flex;flex-direction:column;gap:1rem}.join-field{display:flex;flex-direction:column;text-align:left}.join-field label{font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.06em}.join-field input{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;color:var(--text-primary);background:var(--surface);transition:border-color .15s ease,box-shadow .15s ease}.join-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0ea5e91a}.join-field input:disabled{background:var(--bg);color:var(--text-muted)}.join-error{color:#dc2626;background:#fef2f2;padding:.6rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;border:1px solid #fecaca}.join-submit{padding:.65rem;background:var(--primary);color:var(--text-on-primary);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,transform .1s ease;margin-top:.5rem}.join-submit:hover:not(:disabled){background:var(--primary-hover)}.join-submit:active:not(:disabled){transform:scale(.98)}.join-submit:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.join-consent{font-size:.78rem;color:var(--text-muted);margin:0;line-height:1.4}.join-consent a{color:var(--primary);text-decoration:none}.join-consent a:hover{text-decoration:underline}.policy-container{max-width:680px;margin:0 auto;padding:0;font-family:inherit;line-height:1.7;color:var(--text-primary);background-color:transparent;border-radius:0;box-shadow:none}.policy-container h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary);border-bottom:1px solid var(--border);padding-bottom:.75rem}.policy-container h2{font-size:1.1rem;font-weight:700;margin-top:2rem;margin-bottom:.75rem;color:var(--text-primary)}.policy-container h3{font-size:1rem;font-weight:600;margin-top:1.25rem;margin-bottom:.5rem;color:var(--text-secondary)}.policy-container p{margin-bottom:.75rem;color:var(--text-secondary);font-size:.9rem}.policy-container ul{margin-bottom:.75rem;padding-left:1.5rem}.policy-container li{margin-bottom:.4rem;color:var(--text-secondary);font-size:.9rem}.policy-container a{color:var(--primary);text-decoration:none;font-weight:500}.policy-container a:hover{text-decoration:underline}.last-updated{font-style:italic;color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}
