.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.flex-1{flex:1 1 0%}.flex-wrap{flex-wrap:wrap}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.items-center{align-items:center}.items-start{align-items:flex-start}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (min-width: 640px){.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:col-span-2{grid-column:span 2 / span 2}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.pt-6{padding-top:1.5rem}.pb-8{padding-bottom:2rem}.pl-4{padding-left:1rem}.m-0{margin:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mb-1{margin-bottom:.25rem}.mb-2,.mb-4{margin-bottom:.5rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mx-auto{margin-left:auto;margin-right:auto}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.w-4{width:1rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-12{width:3rem}.w-full{width:100%}.h-4{height:1rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-12{height:3rem}.h-32{height:8rem}.min-h-screen{min-height:100vh}.max-w-md{max-width:28rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-7xl{max-width:80rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.leading-relaxed{line-height:1.625}.text-white{color:#fff}.text-gray-400{color:var(--stone-400)}.text-gray-500{color:var(--stone-500)}.text-gray-600{color:var(--stone-600)}.text-gray-700{color:var(--stone-700)}.text-gray-800{color:var(--stone-800)}.text-gray-900{color:var(--stone-900)}.text-red-500{color:var(--red)}.text-red-700{color:#b91c1c}.text-blue-500,.text-blue-600{color:var(--emerald)}.text-blue-700{color:var(--emerald-dark)}.text-green-600{color:var(--green)}.bg-white{background-color:var(--white)}.bg-gray-50{background-color:var(--stone-50)}.bg-gray-100{background-color:var(--stone-100)}.bg-gray-200{background-color:var(--stone-200)}.bg-blue-50{background-color:var(--emerald-50)}.bg-blue-600{background-color:var(--emerald)}.bg-blue-700{background-color:var(--emerald-dark)}.bg-red-50{background-color:#fef2f2}.bg-red-500{background-color:var(--red)}.bg-red-600{background-color:#dc2626}.bg-red-700{background-color:#b91c1c}.bg-green-600{background-color:var(--green)}.bg-green-700{background-color:#15803d}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from: var(--emerald-50);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-indigo-100{--tw-gradient-to: var(--stone-100)}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-l-4{border-left-width:4px}.border-dashed{border-style:dashed}.border-gray-200{border-color:var(--stone-200)}.border-gray-300{border-color:var(--stone-300)}.border-gray-400{border-color:var(--stone-400)}.border-red-200{border-color:#fecaca}.border-red-500{border-color:var(--red)}.border-blue-500{border-color:var(--emerald)}.border-t-blue-600{border-top-color:var(--emerald)}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.relative{position:relative}.absolute{position:absolute}.top-0{top:0}.top-1{top:.25rem}.right-0{right:0}.right-1{right:.25rem}.bottom-0{bottom:0}.opacity-0{opacity:0}.opacity-50{opacity:.5}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.object-cover{object-fit:cover}.space-y-2>*+*{margin-top:.5rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.hover\:bg-blue-700:hover{background-color:var(--emerald-dark)}.hover\:bg-gray-300:hover{background-color:var(--stone-300)}.hover\:bg-gray-400:hover{background-color:var(--stone-400)}.hover\:bg-red-700:hover{background-color:#b91c1c}.hover\:bg-green-700:hover{background-color:#15803d}.hover\:border-blue-500:hover{border-color:var(--emerald)}.hover\:border-gray-400:hover{border-color:var(--stone-400)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--tw-ring-color)}.focus\:ring-blue-500:focus{--tw-ring-color: var(--emerald)}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.group:hover .group-hover\:opacity-100{opacity:1}:root{--emerald: #047857;--emerald-light: #059669;--emerald-dark: #065f46;--emerald-darker: #034e3b;--emerald-50: #ecfdf5;--gold: #d97706;--gold-light: #f59e0b;--gold-dark: #b45309;--white: #ffffff;--stone-50: #fafaf9;--stone-100: #f5f5f4;--stone-200: #e7e5e4;--stone-300: #d6d3d1;--stone-400: #a8a29e;--stone-500: #78716c;--stone-600: #57534e;--stone-700: #44403c;--stone-800: #292524;--stone-900: #1c1917;--red: #dc2626;--red-light: #fecaca;--green: #16a34a;--green-light: #bbf7d0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--stone-50);color:var(--stone-800);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:Playfair Display,Georgia,serif;color:var(--emerald-dark)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-header{background:linear-gradient(135deg,var(--emerald-darker),var(--emerald));color:var(--white);box-shadow:0 2px 8px #00000026}.app-header-inner{max-width:80rem;margin:0 auto;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.app-logo{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;color:var(--white);text-decoration:none}.app-logo span{color:var(--gold-light)}.app-header-actions{display:flex;align-items:center;gap:1rem}.generations-badge{background:var(--gold);color:var(--white);padding:.25rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:600;font-family:Inter,sans-serif}.header-signout{color:var(--stone-200);background:none;border:none;cursor:pointer;font-size:.875rem;font-family:Inter,sans-serif}.header-signout:hover{color:var(--white);text-decoration:underline}.landing{min-height:100vh}.landing-header{background:linear-gradient(135deg,var(--emerald-darker),var(--emerald));color:var(--white)}.landing-header-inner{max-width:80rem;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.landing-logo{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700;color:var(--white)}.landing-logo span{color:var(--gold-light)}.landing-nav{display:flex;gap:.75rem;align-items:center}.landing-btn-primary{background:var(--gold);color:var(--white);padding:.5rem 1.25rem;border-radius:.5rem;font-weight:600;font-size:.9rem;text-decoration:none;transition:background .15s}.landing-btn-primary:hover{background:var(--gold-dark)}.landing-btn-secondary{color:var(--stone-200);padding:.5rem 1rem;font-size:.9rem;text-decoration:none;transition:color .15s}.landing-btn-secondary:hover{color:var(--white)}.hero{background:linear-gradient(135deg,var(--emerald-darker) 0%,var(--emerald) 50%,var(--emerald-light) 100%);color:var(--white);text-align:center;padding:5rem 1.5rem 6rem}.hero-inner{max-width:50rem;margin:0 auto}.hero h1{font-size:3rem;font-weight:800;color:var(--white);line-height:1.15;margin-bottom:1.25rem}.hero h1 span{color:var(--gold-light)}.hero-subtitle{font-size:1.2rem;color:#ffffffd9;margin-bottom:2.5rem;line-height:1.6;font-family:Inter,sans-serif}.hero-cta{display:inline-block;background:var(--gold);color:var(--white);padding:.875rem 2.5rem;border-radius:.5rem;font-weight:700;font-size:1.1rem;text-decoration:none;transition:background .15s,transform .15s;font-family:Inter,sans-serif}.hero-cta:hover{background:var(--gold-dark);transform:translateY(-1px)}.example-section{padding:5rem 1.5rem 4rem;background:var(--stone-50);overflow:hidden}.example-inner{max-width:60rem;margin:0 auto;text-align:center}.example-inner h2{font-size:2rem;margin-bottom:.5rem}.example-subtitle{color:var(--stone-500);font-size:1rem;margin-bottom:2.5rem}.example-cta-wrap{margin-top:2.5rem}.browser-tilt{perspective:1200px;max-width:52rem;margin:0 auto}.browser-frame{border-radius:.75rem;overflow:hidden;box-shadow:0 25px 60px #0000002e,0 8px 20px #00000014;transform:rotateX(2deg) rotateY(-1deg);transform-origin:center center;transition:transform .4s ease;background:var(--stone-100)}.browser-frame:hover{transform:rotateX(0) rotateY(0)}.browser-bar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:#2d2d2d}.browser-dots{display:flex;gap:.4rem;flex-shrink:0}.dot{width:10px;height:10px;border-radius:50%;background:#555}.dot-red{background:#ff5f57}.dot-yellow{background:#febc2e}.dot-green{background:#28c840}.browser-url{flex:1;text-align:center;background:#1a1a1a;color:#bbb;font-size:.72rem;font-family:Inter,sans-serif;padding:.3rem 1rem;border-radius:.35rem;margin:0 1.5rem;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browser-lock{font-size:.6rem;margin-right:.3rem;opacity:.7}.browser-app-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1.25rem;background:linear-gradient(135deg,var(--emerald-darker),var(--emerald))}.browser-app-logo{font-family:Playfair Display,serif;font-size:1rem;font-weight:700;color:var(--white)}.browser-app-logo em{font-style:normal;color:var(--gold-light)}.browser-content{padding:1.25rem 1.25rem 1rem;background:var(--stone-50);max-height:38rem;overflow-y:auto}@media (max-width: 768px){.browser-frame{transform:none;border-radius:.5rem}.browser-frame:hover{transform:none}.browser-content{max-height:30rem;padding:1rem}.browser-url{margin:0 .5rem}}.features{padding:5rem 1.5rem;background:var(--white)}.features-inner{max-width:70rem;margin:0 auto;text-align:center}.features-inner h2{font-size:2rem;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature-card{background:var(--stone-50);border:1px solid var(--stone-200);border-radius:.75rem;padding:2rem;transition:box-shadow .15s,transform .15s}.feature-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;margin-bottom:.5rem;font-family:Inter,sans-serif;font-weight:600;color:var(--emerald-dark)}.feature-card p{color:var(--stone-500);font-size:.95rem;line-height:1.6}.how-it-works{padding:5rem 1.5rem;background:var(--stone-50)}.how-inner{max-width:60rem;margin:0 auto;text-align:center}.how-inner h2{font-size:2rem;margin-bottom:3rem}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}.step{text-align:center}.step-number{width:3rem;height:3rem;background:var(--emerald);color:var(--white);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;margin-bottom:1rem;font-family:Inter,sans-serif}.step h3{font-size:1.15rem;margin-bottom:.5rem;font-family:Inter,sans-serif;font-weight:600;color:var(--emerald-dark)}.step p{color:var(--stone-500);font-size:.95rem;line-height:1.5}.landing-footer{background:var(--emerald-darker);color:var(--stone-400);text-align:center;padding:2rem 1.5rem;font-size:.875rem;font-family:Inter,sans-serif}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--emerald-darker),var(--emerald));padding:2rem}.auth-card{background:var(--white);border-radius:1rem;box-shadow:0 20px 60px #00000026;padding:2.5rem;width:100%;max-width:24rem}.auth-logo{text-align:center;margin-bottom:1.5rem}.auth-logo a{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700;color:var(--emerald-dark);text-decoration:none}.auth-logo a span{color:var(--gold)}.auth-card h2{text-align:center;font-size:1.5rem;margin-bottom:.25rem}.auth-subtitle{text-align:center;color:var(--stone-500);font-size:.9rem;margin-bottom:1.5rem}.auth-error{background:#fef2f2;color:var(--red);border:1px solid #fecaca;border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--stone-700);margin-bottom:.25rem}.form-group input{width:100%;padding:.625rem .75rem;border:1px solid var(--stone-300);border-radius:.5rem;font-size:.95rem;transition:border-color .15s}.form-group input:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px #0478571a}.form-group small{display:block;color:var(--stone-400);font-size:.75rem;margin-top:.25rem}.auth-btn{width:100%;padding:.75rem;background:var(--emerald);color:var(--white);border:none;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:background .15s;margin-top:.5rem;font-family:Inter,sans-serif}.auth-btn:hover{background:var(--emerald-dark)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;color:var(--stone-500);font-size:.875rem;margin-top:1.5rem}.auth-link a{color:var(--emerald);font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.7rem;background:var(--white);border:1.5px solid var(--stone-300);border-radius:.5rem;font-weight:600;font-size:.95rem;color:var(--stone-700);cursor:pointer;transition:all .15s;font-family:Inter,sans-serif}.google-btn:hover{background:var(--stone-50);border-color:var(--stone-400);box-shadow:0 2px 8px #00000014}.auth-divider{display:flex;align-items:center;margin:1.25rem 0;gap:.75rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--stone-200)}.auth-divider span{font-size:.8rem;color:var(--stone-400);white-space:nowrap}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:1rem;padding-left:1rem}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*:focus-visible{outline:2px solid var(--emerald);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--stone-100)}::-webkit-scrollbar-thumb{background:var(--stone-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--stone-400)}img{max-width:100%;height:auto}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:100%;line-height:inherit;color:inherit;margin:0;padding:0;border:none;background:none;cursor:pointer}input,select,textarea{font-family:inherit;font-size:100%;line-height:inherit;color:inherit;margin:0}:disabled{cursor:not-allowed;opacity:.5}::selection{background-color:var(--emerald-50);color:var(--emerald-dark)}@media (max-width: 768px){.hero h1{font-size:2rem}.hero-subtitle{font-size:1rem}.features-grid{grid-template-columns:1fr}.steps-grid{grid-template-columns:1fr;gap:2rem}.landing-header-inner{flex-direction:column;gap:.75rem}.auth-card{padding:1.5rem}}
