.landing{min-height:100vh;background:var(--ge-cream);color:var(--ge-text-primary)}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#faf9f6e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--ge-border-light)}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center}.landing-nav-brand{display:flex;align-items:center;gap:8px;cursor:pointer}.landing-nav-icon{width:24px;height:24px;color:var(--ge-teal-600)}.landing-nav-icon svg{width:100%;height:100%}.landing-nav-brand span{font-family:var(--font-display);font-size:1rem;font-weight:800;color:var(--ge-teal-700);letter-spacing:.06em}.landing-nav-links{display:flex;align-items:center;gap:24px}.landing-nav-links a{font-size:.88rem;color:var(--ge-text-secondary);text-decoration:none;font-weight:500;transition:color .15s}.landing-nav-links a:hover{color:var(--ge-text-primary)}.landing-nav-cta{padding:8px 20px;border-radius:var(--ge-radius-full);background:var(--ge-teal-600);color:#fff;border:none;font-family:var(--font-body);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.landing-nav-cta:hover{background:var(--ge-teal-700)}@media (max-width: 600px){.landing-nav-links a:not(.landing-nav-cta){display:none}}.landing-hero{position:relative;padding:140px 24px 80px;text-align:center;overflow:hidden;background:linear-gradient(170deg,var(--ge-sage-50) 0%,var(--ge-sage-100) 60%,var(--ge-sage-200) 100%)}.landing-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-doodle{position:absolute;font-size:2.2rem;opacity:.15;animation:heroFloat 8s ease-in-out infinite}.d1{top:15%;left:8%;animation-delay:0s}.d2{top:20%;right:10%;animation-delay:1.5s;font-size:2.8rem}.d3{top:55%;left:5%;animation-delay:3s}.d4{top:40%;right:6%;animation-delay:.8s}.d5{bottom:20%;left:12%;animation-delay:2s}.d6{bottom:15%;right:15%;animation-delay:4s}@keyframes heroFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(4deg)}}.landing-hero-content{position:relative;z-index:1;max-width:680px;margin:0 auto}.landing-hero h1{font-family:var(--font-display);font-size:3.2rem;font-weight:800;line-height:1.1;color:var(--ge-text-primary);margin-bottom:20px}@media (max-width: 600px){.landing-hero h1{font-size:2.2rem}.landing-hero{padding:120px 20px 60px}}.landing-hero-sub{font-size:1.15rem;color:var(--ge-text-secondary);line-height:1.6;margin-bottom:32px;max-width:520px;margin-left:auto;margin-right:auto}@media (max-width: 600px){.landing-hero-sub{font-size:1rem}}.landing-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.btn-lg{padding:16px 36px;font-size:1rem}.btn-outline{background:transparent;color:var(--ge-teal-700);border:2px solid var(--ge-teal-600)}.btn-outline:hover{background:var(--ge-teal-600);color:#fff}.landing-hero-note{margin-top:16px;font-size:.82rem;color:var(--ge-text-muted)}.landing-section{padding:80px 24px}.landing-section-alt{background:var(--ge-white)}.landing-section-inner{max-width:1000px;margin:0 auto}.landing-section-title{font-family:var(--font-display);font-size:2.2rem;font-weight:700;text-align:center;margin-bottom:8px}.landing-section-subtitle{text-align:center;font-size:1.05rem;color:var(--ge-text-secondary);margin-bottom:48px;line-height:1.5}@media (max-width: 600px){.landing-section{padding:56px 20px}.landing-section-title{font-size:1.7rem}.landing-section-subtitle{font-size:.95rem;margin-bottom:32px}}.how-steps{display:flex;align-items:flex-start;justify-content:center;gap:16px}.how-step{flex:1;max-width:280px;text-align:center;background:var(--ge-white);border-radius:var(--ge-radius-xl);padding:32px 24px;border:1px solid var(--ge-border-light);box-shadow:var(--ge-shadow-sm);position:relative}.how-step-number{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:28px;height:28px;border-radius:50%;background:var(--ge-teal-600);color:#fff;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center}.how-step-icon{font-size:2.5rem;margin-bottom:16px}.how-step h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:8px}.how-step p{font-size:.88rem;color:var(--ge-text-secondary);line-height:1.55}.how-step-arrow{color:var(--ge-teal-500);font-size:1.5rem;font-weight:700;padding-top:72px;flex-shrink:0}@media (max-width: 768px){.how-steps{flex-direction:column;align-items:center;gap:24px}.how-step{max-width:340px;width:100%}.how-step-arrow{display:none}}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.feature-card{background:var(--ge-cream);border-radius:var(--ge-radius-lg);padding:28px 24px;border:1px solid var(--ge-border-light);transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-3px);box-shadow:var(--ge-shadow-md)}.feature-icon{font-size:1.8rem;display:block;margin-bottom:14px}.feature-card h3{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:8px}.feature-card p{font-size:.85rem;color:var(--ge-text-secondary);line-height:1.55}@media (max-width: 900px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.features-grid{grid-template-columns:1fr;gap:12px}.feature-card{padding:22px 20px}}.sample-cards{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.sample-card{aspect-ratio:3 / 4;border-radius:var(--ge-radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid rgba(0,0,0,.06)}.sample-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--ge-shadow-lg)}.sample-card-emoji{font-size:2.2rem}.sample-card-label{font-size:.75rem;font-weight:600;color:var(--ge-text-secondary);text-align:center}@media (max-width: 900px){.sample-cards{grid-template-columns:repeat(3,1fr)}}@media (max-width: 500px){.sample-cards{grid-template-columns:repeat(2,1fr);gap:12px}}.landing-cta{padding:80px 24px;background:linear-gradient(170deg,var(--ge-sage-100) 0%,var(--ge-sage-200) 100%);text-align:center}.landing-cta-inner{max-width:560px;margin:0 auto}.landing-cta-icon{width:48px;height:48px;color:var(--ge-teal-600);margin:0 auto 16px}.landing-cta-icon svg{width:100%;height:100%}.landing-cta h2{font-family:var(--font-display);font-size:2rem;font-weight:700;margin-bottom:12px}.landing-cta p{font-size:1rem;color:var(--ge-text-secondary);line-height:1.55;margin-bottom:28px}@media (max-width: 600px){.landing-cta{padding:56px 20px}.landing-cta h2{font-size:1.6rem}}.landing-footer{background:var(--ge-text-primary);padding:40px 24px;color:#fff}.landing-footer-inner{max-width:1000px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.landing-footer-brand{display:flex;align-items:center;gap:8px}.landing-footer-brand .landing-nav-icon{color:var(--ge-sage-300)}.landing-footer-brand span{font-family:var(--font-display);font-size:.95rem;font-weight:800;color:#fff;letter-spacing:.06em}.landing-footer-links{display:flex;gap:24px}.landing-footer-links a{font-size:.85rem;color:var(--ge-sage-300);text-decoration:none;transition:color .15s}.landing-footer-links a:hover{color:#fff}.landing-footer-copy{font-size:.78rem;color:var(--ge-sage-400);width:100%;text-align:center;margin-top:12px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 600px){.landing-footer-inner{flex-direction:column;align-items:center;text-align:center}}.welcome-page{min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;background:linear-gradient(170deg,var(--ge-sage-100) 0%,var(--ge-sage-200) 50%,var(--ge-sage-300) 100%)}.welcome-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.doodle{position:absolute;font-size:2rem;opacity:.2;animation:float 6s ease-in-out infinite}.doodle-1{top:8%;left:10%;animation-delay:0s}.doodle-2{top:12%;right:15%;animation-delay:1s;font-size:2.4rem}.doodle-3{top:30%;left:5%;animation-delay:2s}.doodle-4{top:25%;right:8%;animation-delay:.5s}.doodle-5{top:50%;left:15%;animation-delay:1.5s}.doodle-6{top:45%;right:20%;animation-delay:3s}.doodle-7{top:65%;left:8%;animation-delay:2.5s}.doodle-8{top:60%;right:10%;animation-delay:.8s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(5deg)}}.welcome-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:center;flex:1;padding:40px 24px}.welcome-logo{text-align:center;margin-bottom:48px;animation:fadeInUp .8s ease}.welcome-tagline-above{font-family:var(--font-body);font-size:1.1rem;font-weight:400;color:var(--ge-text-secondary);letter-spacing:.02em}.welcome-brand{margin-top:8px}.welcome-icon{width:56px;height:56px;margin:0 auto 8px;color:var(--ge-teal-600)}.welcome-icon svg{width:100%;height:100%}.welcome-brand h1{font-family:var(--font-display);font-size:3.5rem;font-weight:800;line-height:.95;color:var(--ge-teal-700);letter-spacing:.04em}.welcome-tagline{margin-top:20px;font-family:var(--font-body);font-size:.95rem;color:var(--ge-text-secondary);line-height:1.5;max-width:280px;margin-left:auto;margin-right:auto;text-align:center}.welcome-actions{width:100%;max-width:340px;display:flex;flex-direction:column;gap:12px;animation:fadeInUp .8s ease .2s both}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--ge-bg-page)}.auth-card{width:100%;max-width:400px;padding:36px 28px;background:var(--ge-bg-card);border-radius:var(--ge-radius-xl);box-shadow:var(--ge-shadow-md);border:1px solid var(--ge-border-light)}.auth-card h1{font-family:var(--font-display);font-size:1.7rem;font-weight:700;text-align:center;margin-bottom:24px;color:var(--ge-text-primary)}.auth-tagline{text-align:center;font-size:.88rem;color:var(--ge-text-secondary);margin-bottom:24px;line-height:1.4;font-style:italic}.auth-error{background:#fef2f2;color:var(--ge-red);padding:10px 14px;border-radius:var(--ge-radius-sm);font-size:.85rem;margin-bottom:14px;border:1px solid rgba(212,83,74,.15)}.input-with-icon{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:.9rem;pointer-events:none;opacity:.5}.input-with-icon .input-field{padding-left:42px}.auth-forgot{text-align:right;margin-bottom:16px}.auth-forgot a{font-size:.82rem;color:var(--ge-teal-600);text-decoration:none;font-weight:600}.auth-forgot a:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;margin:24px 0;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--ge-border-medium)}.auth-divider span{font-size:.82rem;color:var(--ge-text-muted);font-weight:500}.auth-social{display:flex;justify-content:center;gap:16px;margin-bottom:24px}.social-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--ge-border-medium);background:var(--ge-white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.social-btn:hover{transform:translateY(-2px);box-shadow:var(--ge-shadow-md);border-color:transparent}.auth-footer{text-align:center;font-size:.88rem;color:var(--ge-text-muted);margin-top:20px}.auth-footer a{color:var(--ge-teal-600);font-weight:700;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.onboarding-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--ge-bg-page)}.onboarding-card{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;padding:32px 24px}.onboarding-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.onboarding-logo-icon{width:32px;height:32px;color:var(--ge-teal-600);margin-bottom:4px}.onboarding-logo-icon svg{width:100%;height:100%}.onboarding-logo-text{font-family:var(--font-display);font-size:1.1rem;font-weight:800;color:var(--ge-teal-700);letter-spacing:.04em}.onboarding-illustration{width:100%;height:220px;background:var(--ge-bg-card);border-radius:var(--ge-radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:28px;box-shadow:var(--ge-shadow-sm);border:1px solid var(--ge-border-light)}.onboarding-emoji{font-size:5rem;line-height:1;animation:bounceIn .5s ease}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.onboarding-text{text-align:center;margin-bottom:28px;background:var(--ge-bg-card);border-radius:var(--ge-radius-lg);padding:24px 20px;width:100%;box-shadow:var(--ge-shadow-sm);border:1px solid var(--ge-border-light)}.onboarding-text h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--ge-text-primary);margin-bottom:10px}.onboarding-text p{font-size:.9rem;color:var(--ge-text-secondary);line-height:1.55}.onboarding-dots{display:flex;gap:8px;margin-bottom:24px}.onboarding-dot{width:10px;height:10px;border-radius:50%;border:none;background:var(--ge-sage-300);cursor:pointer;padding:0;transition:all .2s}.onboarding-dot.active{background:var(--ge-teal-600);transform:scale(1.2)}.card-flow-page{min-height:100vh;background:var(--ge-bg-page, var(--ge-sage-300));display:flex;flex-direction:column;max-width:600px;margin:0 auto}@media (min-width: 768px){.card-flow-page{margin-left:calc(var(--sidebar-width) + (100% - var(--sidebar-width) - 600px) / 2)}}.card-flow-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--ge-sage-100);border-radius:0 0 var(--ge-radius-lg) var(--ge-radius-lg)}.card-flow-header h1{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.card-flow-back{background:none;border:none;cursor:pointer;width:24px;height:24px;color:var(--ge-text-primary);padding:0}.card-flow-back svg{width:24px;height:24px}.step-indicator{display:flex;justify-content:center;gap:24px;padding:16px 20px}.step-dot-group{display:flex;flex-direction:column;align-items:center;gap:4px}.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;background:var(--ge-sage-200);color:var(--ge-text-muted);transition:all .2s}.step-dot-group.active .step-dot{background:var(--ge-teal-600);color:#fff}.step-dot-group.done .step-dot{background:var(--ge-green-check);color:#fff}.step-dot-label{font-size:.68rem;color:var(--ge-text-muted);font-weight:500}.step-dot-group.active .step-dot-label{color:var(--ge-text-primary);font-weight:700}.card-flow-content{flex:1;padding:0 20px 100px;overflow-y:auto}.step-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:4px}.step-subtitle{font-size:.85rem;color:var(--ge-text-muted);margin-bottom:20px}.card-filter-bar{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.card-filter-chip{padding:6px 14px;border-radius:var(--ge-radius-full);border:none;font-size:.78rem;font-weight:600;cursor:pointer;font-family:var(--font-body);background:var(--ge-sage-100);color:var(--ge-text-secondary);white-space:nowrap;transition:all .15s}.card-filter-chip.active{background:var(--ge-teal-600);color:#fff}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (min-width: 500px){.card-grid{grid-template-columns:repeat(3,1fr)}}.card-option{border-radius:var(--ge-radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .15s;background:var(--ge-sage-100)}.card-option:hover{border-color:var(--ge-sage-400)}.card-option.selected{border-color:var(--ge-teal-600);box-shadow:0 0 0 1px var(--ge-teal-600)}.card-preview{aspect-ratio:3 / 4;display:flex;align-items:center;justify-content:center}.card-preview img{width:100%;height:100%;object-fit:cover}.card-preview-placeholder{font-size:2.5rem;opacity:.5}.card-option-info{padding:8px 10px;display:flex;justify-content:space-between;align-items:center}.card-option-name{font-size:.78rem;font-weight:600;color:var(--ge-text-primary)}.card-option-price{font-size:.75rem;font-weight:700;color:var(--ge-teal-600)}.font-list{display:flex;flex-direction:column;gap:10px}.font-option{padding:16px 20px;background:var(--ge-sage-100);border-radius:var(--ge-radius-md);cursor:pointer;border:2px solid transparent;transition:all .15s;display:flex;flex-direction:column;align-items:center;text-align:center}.font-option:hover{border-color:var(--ge-sage-400)}.font-option.selected{border-color:var(--ge-teal-600);background:var(--ge-sage-50)}.font-sample{font-size:1.1rem;font-style:italic;color:var(--ge-text-primary);margin-bottom:6px;line-height:1.4}.font-name{font-size:.75rem;color:var(--ge-text-muted);font-weight:600}.message-editor{background:var(--ge-sage-100);border-radius:var(--ge-radius-md);padding:16px}.message-textarea{width:100%;border:none;background:var(--ge-sage-50, var(--ge-bg-input, white));border-radius:var(--ge-radius-sm);padding:14px;font-family:var(--font-body);font-size:.92rem;color:var(--ge-text-primary);resize:vertical;outline:none;line-height:1.6;min-height:200px}.message-textarea:focus{box-shadow:0 0 0 2px var(--ge-teal-500)}.message-actions{margin-top:12px;display:flex;justify-content:flex-end}.btn-generate{padding:8px 16px;border-radius:var(--ge-radius-full);border:1.5px solid var(--ge-teal-500);background:transparent;color:var(--ge-teal-600);font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .15s}.btn-generate:hover{background:var(--ge-teal-600);color:#fff}.btn-generate:disabled{opacity:.6;cursor:not-allowed}.message-signature{margin-top:12px;font-size:.82rem;color:var(--ge-text-muted);padding:8px 12px;background:var(--ge-sage-50, var(--ge-bg-input, white));border-radius:var(--ge-radius-sm)}.message-signature strong{color:var(--ge-teal-700)}.review-sections{display:flex;flex-direction:column;gap:16px}.review-card-preview{display:grid;grid-template-columns:1fr 1fr;gap:12px}.review-card-front{aspect-ratio:3 / 4;border-radius:var(--ge-radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;overflow:hidden;background:var(--ge-sage-100)}.review-card-name{font-size:.78rem;font-weight:600;color:var(--ge-text-primary)}.review-card-inside{background:var(--ge-sage-50, var(--ge-bg-input, white));border-radius:var(--ge-radius-md);padding:14px;display:flex;align-items:flex-start}.review-message{font-family:var(--font-body);font-size:.75rem;white-space:pre-wrap;color:var(--ge-text-primary);line-height:1.5;margin:0}.review-details{background:var(--ge-sage-100);border-radius:var(--ge-radius-md);padding:14px}.review-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--ge-sage-200)}.review-row:last-child{border-bottom:none}.review-row.total{border-top:2px solid var(--ge-teal-500);border-bottom:none;padding-top:12px;margin-top:4px}.review-label{font-size:.82rem;color:var(--ge-text-muted)}.review-value{font-size:.82rem;font-weight:600;color:var(--ge-text-primary);text-align:right;max-width:60%}.review-row.total .review-value{color:var(--ge-teal-700);font-size:.95rem}.card-flow-footer{position:fixed;bottom:0;left:0;right:0;max-width:600px;margin:0 auto;padding:16px 20px 28px;background:var(--ge-bg-page, var(--ge-sage-300))}@media (min-width: 768px){.card-flow-footer{margin-left:calc(var(--sidebar-width) + (100% - var(--sidebar-width) - 600px) / 2)}}html{scroll-behavior:smooth}:root{--ge-sage-50: #f6f8f4;--ge-sage-100: #eaf0e8;--ge-sage-200: #d6e2d3;--ge-sage-300: #b8ccb4;--ge-sage-400: #95b190;--ge-sage-500: #7a9e7a;--ge-sage-600: #6b8f6b;--ge-sage-700: #5a7a5a;--ge-teal-500: #2a7c7c;--ge-teal-600: #1f6b6b;--ge-teal-700: #185a5a;--ge-white: #ffffff;--ge-cream: #faf9f6;--ge-cream-warm: #f5f2ed;--ge-sand: #ece8e1;--ge-bg-page: #eef2eb;--ge-bg-sidebar: #f5f7f3;--ge-bg-card: #ffffff;--ge-bg-modal: #faf9f6;--ge-bg-input: #ffffff;--ge-text-primary: #1b2a1b;--ge-text-secondary: #4a5c4a;--ge-text-muted: #8a9a8a;--ge-text-light: #b0bab0;--ge-border-light: rgba(0, 0, 0, .06);--ge-border-medium: rgba(0, 0, 0, .1);--ge-border-input: rgba(0, 0, 0, .12);--ge-orange: #e8913a;--ge-amber: #d4a24e;--ge-red: #d4534a;--ge-green-check: #4a9a5a;--ge-shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--ge-shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);--ge-shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--ge-shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--ge-radius-sm: 8px;--ge-radius-md: 12px;--ge-radius-lg: 16px;--ge-radius-xl: 24px;--ge-radius-full: 9999px;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--sidebar-width: 250px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-body);color:var(--ge-text-primary);background:var(--ge-bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{min-height:100vh;background:var(--ge-bg-page);display:flex;flex-direction:column}@media (min-width: 768px){.app-shell{margin-left:var(--sidebar-width)}}.sidebar{display:none}@media (min-width: 768px){.sidebar{display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--ge-bg-sidebar);padding:28px 18px;z-index:100;border-right:1px solid var(--ge-border-light)}}.sidebar-logo{text-align:center;margin-bottom:36px;cursor:pointer;padding-bottom:24px;border-bottom:1px solid var(--ge-border-light)}.sidebar-logo-icon{width:32px;height:32px;margin:0 auto 6px;color:var(--ge-teal-600)}.sidebar-logo-icon svg{width:100%;height:100%}.sidebar-logo-text{display:block;font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--ge-teal-700);letter-spacing:.06em}.sidebar-logo-tagline{display:block;font-size:.68rem;color:var(--ge-text-muted);margin-top:3px;letter-spacing:.02em}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1;padding-top:8px}.sidebar-item{display:flex;align-items:center;gap:14px;padding:11px 16px;border-radius:var(--ge-radius-md);border:none;background:none;cursor:pointer;font-family:var(--font-body);font-size:.9rem;font-weight:400;color:var(--ge-text-secondary);transition:all .15s ease;text-align:left;width:100%}.sidebar-item svg{width:20px;height:20px;flex-shrink:0;opacity:.7}.sidebar-item:hover{background:var(--ge-sage-100);color:var(--ge-text-primary)}.sidebar-item:hover svg{opacity:1}.sidebar-item.active{background:var(--ge-teal-600);color:#fff;font-weight:600}.sidebar-item.active svg{opacity:1}.sidebar-user{display:flex;align-items:center;gap:12px;padding:20px 16px 14px;cursor:pointer;border-radius:var(--ge-radius-md);transition:background .15s;border-top:1px solid var(--ge-border-light);margin-top:8px}.sidebar-user:hover{background:var(--ge-sage-100)}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--ge-sage-200);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--ge-teal-700);flex-shrink:0}.sidebar-username{font-size:.85rem;font-weight:600;color:var(--ge-text-primary)}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:8px 0 20px;background:var(--ge-white);border-top:1px solid var(--ge-border-light);z-index:100}@media (min-width: 768px){.tab-bar{display:none}}.tab-item{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;padding:4px 12px;color:var(--ge-text-muted);transition:color .2s;font-family:var(--font-body);font-size:.68rem;font-weight:500}.tab-item.active{color:var(--ge-teal-600);font-weight:700}.tab-item svg{width:22px;height:22px}.page-content{flex:1;overflow-y:auto;padding-bottom:80px}@media (min-width: 768px){.page-content{padding-bottom:32px;max-width:960px;margin:0 auto;width:100%;padding-left:40px;padding-right:40px}}.header-bar{padding:16px 20px 12px;position:relative;text-align:center}.header-bar h1{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--ge-text-primary)}@media (min-width: 768px){.header-bar{padding:48px 0 16px;text-align:left}.header-bar h1{font-size:2rem}}.header-bar .header-action{position:absolute;right:20px;top:50%;transform:translateY(-50%);background:var(--ge-bg-card);border:1px solid var(--ge-border-light);color:var(--ge-text-secondary);cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}.header-bar .header-action:hover{background:var(--ge-sage-100)}.header-bar .header-action svg{width:18px;height:18px}@media (min-width: 768px){.header-bar .header-action{right:32px}}.card{background:var(--ge-bg-card);border-radius:var(--ge-radius-lg);padding:14px 16px;margin:0 20px 8px;box-shadow:var(--ge-shadow-sm);border:1px solid var(--ge-border-light);transition:box-shadow .15s,transform .15s}.card:hover{box-shadow:var(--ge-shadow-md);transform:translateY(-1px)}@media (min-width: 768px){.card{margin:0 0 10px}}.card-bordered{border-left:3px solid var(--ge-teal-500)}.card-grid,.events-grid,.persons-grid{display:flex;flex-direction:column}@media (min-width: 768px){.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;padding:0}.card-grid .card{margin:0}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;padding:0}.events-grid .card{margin:0}.persons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;padding:0}.persons-grid .card{margin:0}}.upcoming-events-row{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 16px}.upcoming-events-row .card{scroll-snap-align:start;min-width:160px;margin:0;flex-shrink:0}@media (min-width: 768px){.upcoming-events-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:0!important;overflow-x:visible}.upcoming-events-row .card{min-width:unset;margin:0}}.section-header{display:flex;justify-content:space-between;align-items:baseline;padding:18px 20px 8px}@media (min-width: 768px){.section-header{padding:24px 0 12px}}.section-header h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--ge-text-primary);padding-left:14px;border-left:3px solid var(--ge-teal-600)}.section-header a,.section-header button{font-size:.82rem;color:var(--ge-teal-600);text-decoration:none;background:none;border:none;cursor:pointer;font-weight:600;font-family:var(--font-body)}.section-header button:hover{text-decoration:underline}.content-padded{padding:0 20px}@media (min-width: 768px){.content-padded{padding:0}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--ge-radius-full);font-family:var(--font-body);font-weight:600;font-size:.92rem;cursor:pointer;border:none;transition:all .2s ease;text-decoration:none}.btn-primary{background:var(--ge-teal-600);color:#fff;box-shadow:0 2px 8px #1f6b6b40}.btn-primary:hover{background:var(--ge-teal-700);transform:translateY(-1px);box-shadow:0 4px 16px #1f6b6b4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--ge-white);color:var(--ge-text-primary);border:1px solid var(--ge-border-medium)}.btn-secondary:hover{background:var(--ge-sage-50)}.btn-full{width:100%}.btn-text{background:none;color:var(--ge-text-secondary);padding:8px}.btn-text:hover{color:var(--ge-text-primary)}.input-group{margin-bottom:12px}.input-group label{display:block;font-size:.78rem;font-weight:600;color:var(--ge-text-secondary);margin-bottom:5px;letter-spacing:.01em}.input-field{width:100%;padding:13px 16px;border:1px solid var(--ge-border-input);border-radius:var(--ge-radius-sm);background:var(--ge-bg-input);font-family:var(--font-body);font-size:.92rem;color:var(--ge-text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:var(--ge-teal-500);box-shadow:0 0 0 3px #2a7c7c1a}.input-field::placeholder{color:var(--ge-text-light)}select.input-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238a9a8a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--ge-sage-100);display:flex;align-items:center;justify-content:center;color:var(--ge-teal-700);font-weight:700;font-size:1rem;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-lg{width:90px;height:90px;font-size:2rem}.chip{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:var(--ge-radius-full);font-size:.7rem;font-weight:600;background:var(--ge-sage-50);color:var(--ge-teal-600);border:1px solid var(--ge-sage-200)}.filter-bar{display:flex;gap:0;padding:0 20px;margin-bottom:16px}@media (min-width: 768px){.filter-bar{padding:0;max-width:500px}}.filter-tab{flex:1;padding:10px;text-align:center;background:none;border:none;border-bottom:2px solid transparent;font-family:var(--font-body);font-size:.88rem;color:var(--ge-text-muted);cursor:pointer;transition:all .2s;font-weight:500}.filter-tab.active{color:var(--ge-teal-600);font-weight:700;border-bottom-color:var(--ge-teal-600)}.fab{position:fixed;bottom:90px;right:20px;width:54px;height:54px;border-radius:50%;background:var(--ge-teal-600);color:#fff;border:none;font-size:1.6rem;cursor:pointer;box-shadow:0 4px 16px #1f6b6b59;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:50}.fab:hover{background:var(--ge-teal-700);transform:scale(1.08);box-shadow:0 6px 24px #1f6b6b66}.fab svg{width:24px;height:24px}@media (min-width: 768px){.fab{bottom:32px;right:32px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-in{animation:fadeInUp .35s ease forwards}.animate-fade{animation:fadeIn .25s ease forwards}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:flex-end;justify-content:center}@media (min-width: 768px){.modal-overlay{align-items:center}}.modal-content{background:var(--ge-bg-modal);width:100%;max-width:460px;max-height:90vh;border-radius:var(--ge-radius-xl) var(--ge-radius-xl) 0 0;padding:28px 24px 40px;overflow-y:auto;animation:slideUp .3s ease;box-shadow:var(--ge-shadow-lg)}@media (min-width: 768px){.modal-content{border-radius:var(--ge-radius-xl);max-width:520px;animation:fadeIn .2s ease}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700}.modal-close{background:var(--ge-sage-100);border:none;font-size:1.1rem;cursor:pointer;color:var(--ge-text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s}.modal-close:hover{background:var(--ge-sage-200)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--ge-white);border-radius:var(--ge-radius-sm);margin-bottom:10px;border:1px solid var(--ge-border-light)}.toggle-row span{font-size:.9rem;font-weight:500}.toggle{width:46px;height:26px;border-radius:13px;background:var(--ge-sage-300);position:relative;cursor:pointer;border:none;transition:background .2s}.toggle.on{background:var(--ge-teal-500)}.toggle:after{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.toggle.on:after{transform:translate(20px)}.empty-state{text-align:center;padding:48px 20px;color:var(--ge-text-muted)}.empty-state p{font-size:.95rem;margin-bottom:16px;line-height:1.5}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--ge-sage-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ge-sage-400)}@media (min-width: 768px){.header-bar{text-align:center;padding:28px 40px 20px;border-radius:0;background:transparent}.header-bar h1{font-size:1.8rem}}@media (min-width: 768px){.app-shell .header-bar{padding:28px 40px 20px;text-align:left;background:transparent;border-radius:0}}@keyframes ge-spinner{to{transform:rotate(360deg)}}
