*{box-sizing:border-box;margin:0;padding:0}:root{--bg-1: #0f172a;--bg-2: #1e293b;--accent: #f472b6;--accent-soft: #f9a8d4;--card-bg: rgba(15, 23, 42, .95);--text-main: #e5e7eb;--text-soft: #cbd5f5}body{font-family:Montserrat,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,#1f2937 0,#020617 55%);color:var(--text-main);min-height:100vh}.app-root{min-height:100vh;display:flex;flex-direction:column;background:transparent}.app-header{width:100%;position:relative;z-index:5;background:radial-gradient(circle at top,#1f2937 0,#020617 55%);border-bottom:1px solid rgba(148,163,184,.45);box-shadow:0 18px 40px #0f172ae6}.app-header-inner{max-width:1100px;margin:0 auto;padding:1rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.app-header-left{display:flex;flex-direction:column;gap:.1rem}.app-title{font-family:Dancing Script,cursive;font-size:2.4rem;color:var(--accent-soft)}.app-subtitle{font-size:.95rem;color:var(--text-soft)}.profile-menu{position:relative;z-index:6;display:flex;align-items:center;justify-content:flex-end}.profile-button{width:42px;height:42px;border-radius:999px;border:1px solid rgba(191,219,254,.9);background:radial-gradient(circle at top left,#f472b6,#1f2937);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 25px #0f172ae6}.profile-button:hover{filter:brightness(1.05)}.profile-initials{font-size:.9rem;font-weight:700;color:#f9fafb}.profile-dropdown{position:absolute;top:120%;right:0;width:220px;background:#0f172af7;border-radius:16px;border:1px solid rgba(148,163,184,.9);padding:.75rem .8rem;box-shadow:0 20px 40px #0f172af2;z-index:20}.profile-info{padding-bottom:.6rem;border-bottom:1px solid rgba(51,65,85,.9);margin-bottom:.4rem}.profile-name{font-size:.9rem;font-weight:600}.profile-email{font-size:.78rem;color:#9ca3af;margin-top:.12rem}.profile-dropdown-item{width:100%;text-align:left;border:none;background:transparent;color:#fecaca;font-size:.85rem;padding:.45rem .1rem .25rem;cursor:pointer}.page{position:relative;flex:1;display:flex;justify-content:center;padding:2rem 1rem 2.4rem}.app-content{width:100%;max-width:1100px}.page-centered{display:flex;align-items:center;justify-content:center}.hearts{position:absolute;font-size:2.5rem;opacity:.2;animation:float 10s infinite ease-in-out;pointer-events:none;z-index:0}.hearts-1{top:10%;left:8%}.hearts-2{bottom:5%;right:10%;animation-duration:14s}.hearts-3{top:55%;right:45%;animation-duration:18s}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-18px)}to{transform:translateY(0)}}.auth-card,.letter-card{width:100%;max-width:900px;background:linear-gradient(135deg,#f8fafc05,#0f172ae6),var(--card-bg);border-radius:24px;border:1px solid rgba(148,163,184,.5);padding:2.4rem 2rem;box-shadow:0 24px 60px #0f172ae6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:relative;overflow:hidden}.auth-card:before,.letter-card:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at top,rgba(244,114,182,.12),transparent 55%);opacity:.9;pointer-events:none}.intro-title{font-family:Dancing Script,cursive;font-size:3rem;color:#f9a8d4;text-align:center;margin-bottom:1rem}.intro-text{text-align:center;color:var(--text-soft);font-size:1rem;margin-bottom:1.8rem}.open-button{display:inline-flex;align-items:center;justify-content:center;margin:0 auto;padding:.85rem 2.4rem;border-radius:999px;border:none;font-size:1rem;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#f472b6,#fb7185);color:#020617;box-shadow:0 10px 25px #f871b473;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.open-button:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 14px 32px #f871b48c;filter:brightness(1.05)}.open-button:active{transform:translateY(1px) scale(.99);box-shadow:0 6px 18px #f871b459}.small-note{text-align:center;margin-top:1.4rem;font-size:.8rem;color:#9ca3af}.auth-header{position:relative;z-index:1}.auth-tabs{display:inline-flex;border-radius:999px;padding:.2rem;background:#0f172ae0;border:1px solid rgba(148,163,184,.5);margin:0 auto 1.6rem;position:relative;z-index:1}.auth-tab{border:none;background:transparent;color:#9ca3af;font-size:.9rem;padding:.5rem 1.3rem;border-radius:999px;cursor:pointer;transition:background .15s ease,color .15s ease}.auth-tab-active{background:#0f172af7;color:var(--text-main)}.auth-form{position:relative;z-index:1}.auth-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.auth-field label{font-size:.85rem;color:#e5e7eb}.auth-field input{padding:.6rem .8rem;border-radius:.7rem;border:1px solid rgba(148,163,184,.7);background:#0f172ae6;color:var(--text-main);font-size:.9rem}.auth-field input:focus{outline:none;border-color:#f9a8d4;box-shadow:0 0 0 1px #f9a8d466}.auth-error{margin-bottom:.9rem;font-size:.85rem;color:#fecaca;background:#ef44441f;border-radius:.7rem;padding:.5rem .7rem}.auth-submit{width:100%;margin-top:.4rem}.dashboard{position:relative;z-index:1;background:linear-gradient(135deg,#0f172af5,#0f172ae6);border-radius:24px;border:1px solid rgba(148,163,184,.7);padding:1.5rem 1.4rem 1.7rem;box-shadow:0 24px 60px #0f172ae6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.section-title{font-size:.95rem;font-weight:600;color:#e5e7eb;margin-bottom:.7rem}.letters-list{min-width:0}.letters-grid{display:flex;flex-direction:column;gap:.7rem;max-height:420px;overflow-y:auto;padding-right:.3rem}.letters-hint{margin-top:.6rem;font-size:.8rem;color:#9ca3af;text-align:left}.letters-grid::-webkit-scrollbar{width:6px}.letters-grid::-webkit-scrollbar-track{background:transparent}.letters-grid::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px}.letter-tile{width:100%;border-radius:16px;border:1px solid rgba(148,163,184,.6);background:radial-gradient(circle at top,#0f172afa,#0f172af2);padding:.85rem .9rem;display:grid;grid-template-columns:auto 1fr;gap:.75rem;cursor:pointer;text-align:left;transition:border-color .15s ease,transform .12s ease,box-shadow .12s ease,background .15s ease;align-items:center}.letter-tile:hover{transform:translateY(-1px);box-shadow:0 10px 25px #0f172ae6;border-color:#f9a8d4e6}.letter-tile-active{background:radial-gradient(circle at top right,#ec489940,#0f172af7);border-color:#fb7185e6}.letter-tile-date{width:68px;height:76px;border-radius:14px;background:#f9fafb;border:1px solid #e5e7eb;overflow:hidden;display:flex;flex-direction:column}.date-month{background:#ef4444;color:#f9fafb;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-align:center;padding:.18rem .2rem}.date-day{flex:1;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#111827}.letter-tile-body{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}.letter-tile-title{font-size:.95rem;font-weight:600;color:#e5e7eb;text-align:left}.letter-tile-excerpt{font-size:.8rem;color:#9ca3af;text-align:left}.letter-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.4rem;position:relative;z-index:1}.letter-header h1{font-family:Dancing Script,cursive;font-size:2.1rem;color:var(--accent-soft)}.letter-date{font-size:.85rem;color:#9ca3af}.letter-body{margin-top:.75rem;line-height:1.7;font-size:.98rem;color:var(--text-soft);position:relative;z-index:1}.letter-greeting{margin-bottom:.8rem}.letter-paragraph{margin-bottom:.9rem}.letter-closing{margin-top:1.4rem}.letter-signature{font-family:Dancing Script,cursive;font-size:1.6rem;margin-top:.3rem;color:#fbcfe8}.letter-footer{margin-top:1.8rem;padding-top:.9rem;border-top:1px dashed rgba(148,163,184,.6);font-size:.85rem;color:#9ca3af}.letter-close-button{position:absolute;top:1.1rem;right:1.3rem;z-index:3;border:none;border-radius:999px;padding:.2rem .55rem;background:#0f172ad9;color:#e5e7eb;font-size:.9rem;cursor:pointer}.letter-modal-backdrop{position:fixed;inset:0;background:#0f172aeb;display:flex;align-items:center;justify-content:center;padding:1.5rem 1rem;z-index:30;overflow-y:auto}.letter-modal-inner{width:100%;max-width:780px;margin:auto;display:flex;justify-content:center}.letter-card{max-height:calc(100vh - 3rem);overflow-y:auto}.google-button{margin-top:.9rem;width:100%;padding:.7rem 1rem;border-radius:999px;border:1px solid rgba(148,163,184,.8);background:#f9fafb;color:#111827;font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer}.google-button:hover{background:#e5e7eb}@media(max-width:800px){.app-header-inner{padding:.9rem 1rem}.app-title{font-size:2rem}.page{padding:1.6rem .8rem 2rem}.dashboard{padding:1.3rem 1.1rem 1.5rem;border-radius:22px}.letters-grid{max-height:260px}.letter-card{padding:2rem 1.4rem}.letter-body{font-size:.96rem;line-height:1.8}}@media(max-width:600px){.app-header-inner{flex-direction:row;align-items:flex-start}.app-title{font-size:1.9rem}.app-subtitle{font-size:.9rem}.auth-card,.letter-card,.dashboard{padding:1.7rem 1.2rem;border-radius:20px}.letters-grid{max-height:240px;padding-right:0}.letter-tile{padding:.8rem}.letter-header h1{font-size:1.8rem}.letter-modal-backdrop{align-items:flex-start;padding-top:4.5rem}.letter-card{max-height:calc(100vh - 5.5rem)}.auth-tabs{width:100%}.auth-tab{width:50%}}
