@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Playfair+Display:wght@700;900&display=swap";:root{--bg-gradient:linear-gradient(135deg, #fdf6f0 0%, #fce4ec 100%);--primary:#c9748f;--secondary:#e8c97e;--text:#3d2b1f;--card-bg:#ffffffb3;--glass-border:#ffffff80;--shadow:0 8px 32px 0 #c9748f1a;--font-heading:"Playfair Display", serif;--font-body:"Inter", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-gradient);color:var(--text);justify-content:center;align-items:flex-start;min-height:100vh;display:flex;overflow-x:hidden}#root{flex-direction:column;width:100%;max-width:480px;min-height:100vh;padding:1rem 1.5rem 80px;display:flex;position:relative}h1,h2,h3{font-family:var(--font-heading)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(0)rotate(0)}50%{transform:translateY(-20px)rotate(5deg)}to{transform:translateY(0)rotate(0)}}.fade-in{animation:.8s ease-out forwards fadeIn}.float{animation:6s ease-in-out infinite float}.app-header-top{justify-content:flex-end;margin-bottom:1rem;display:flex}.lang-btn{background:var(--card-bg);border:1px solid var(--glass-border);color:var(--text);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:.5rem 1rem;font-weight:600;transition:all .3s}.lang-btn:hover{background:var(--primary);color:#fff}.bottom-nav{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:1px solid var(--glass-border);z-index:1000;background:#ffffffd9;justify-content:space-around;width:100%;max-width:480px;padding:.75rem .5rem;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -4px 20px #0000000d}.nav-item{color:#a0a0a0;flex-direction:column;align-items:center;gap:4px;text-decoration:none;transition:all .3s;display:flex}.nav-item.active{color:var(--primary)}.nav-icon{font-size:1.25rem}.nav-label{font-size:.7rem;font-weight:600}.app-container{flex-direction:column;flex:1;align-items:center;gap:2rem;display:flex}.app-header{text-align:center;margin-bottom:1rem}.app-header h1{color:var(--text);margin-bottom:.25rem;font-size:2.5rem}.app-header p{color:var(--primary);letter-spacing:.1em;font-weight:500}.side-cards{gap:1rem;width:100%;margin-top:auto;display:flex}.app-footer{text-align:center;opacity:.5;margin-top:auto;padding:2rem 0;font-size:.8rem}.page-container{flex-direction:column;gap:1.5rem;width:100%;display:flex}.hero-card{text-align:center;box-shadow:var(--shadow);border:1px solid var(--glass-border);border-radius:24px;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;display:flex}.hero-emoji{font-size:4rem}.hero-info h2{margin-bottom:.25rem;font-size:1.5rem}.hero-countdown{color:var(--primary);background:#fff;border-radius:50px;padding:.5rem 1rem;font-size:1.25rem;font-weight:700}.today-badge{color:#ff4081;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.events-list{flex-direction:column;gap:1rem;display:flex}.event-item{background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:16px;align-items:center;gap:1rem;padding:1rem;transition:transform .2s;display:flex}.event-item.past{opacity:.5;filter:grayscale(.5)}.event-icon{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex}.event-details{flex:1}.event-details h3{margin-bottom:.1rem;font-size:1rem}.event-details p{opacity:.7;font-size:.8rem}.event-actions{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.event-days{color:var(--primary);font-size:.75rem;font-weight:600}.delete-btn{cursor:pointer;opacity:0;background:0 0;border:none;transition:opacity .2s}.event-item:hover .delete-btn{opacity:1}.fab{background:var(--primary);color:#fff;cursor:pointer;z-index:900;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:2rem;transition:transform .2s;display:flex;position:fixed;bottom:100px;right:20px;box-shadow:0 4px 12px #0003}.fab:hover{transform:scale(1.1)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:24px;width:100%;max-width:400px;padding:2rem;box-shadow:0 10px 40px #0000001a}.form-group{margin-bottom:1.25rem}.form-group label{opacity:.8;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.form-group input[type=text],.form-group input[type=date]{background:#f9f9f9;border:1px solid #eee;border-radius:12px;width:100%;padding:.75rem;font-family:inherit}.type-radios{flex-wrap:wrap;gap:.5rem;display:flex}.type-radio{text-align:center;cursor:pointer;border:1px solid #eee;border-radius:10px;flex:1;padding:.5rem;font-size:.75rem}.type-radio input{display:none}.type-radio.active{background:var(--primary);color:#fff;border-color:var(--primary)}.emoji-grid{flex-wrap:wrap;gap:.5rem;display:flex}.emoji-grid button{cursor:pointer;background:#f5f5f5;border:1px solid #0000;border-radius:8px;padding:.5rem;font-size:1.25rem}.emoji-grid button.active{border-color:var(--primary);background:#fff}.form-actions{gap:1rem;margin-top:2rem;display:flex}.form-actions button{cursor:pointer;background:#fff;border:1px solid #eee;border-radius:12px;flex:1;padding:.75rem;font-weight:600}.primary-btn{background:var(--primary)!important;color:#fff!important;border:none!important}.loader{opacity:.5;justify-content:center;align-items:center;padding:4rem;font-weight:600;display:flex}.shopping-header{margin-bottom:1.5rem}.shopping-title-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.clear-btn{border:1px solid var(--primary);color:var(--primary);cursor:pointer;background:#c9748f1a;border-radius:8px;padding:.4rem .8rem;font-size:.75rem;font-weight:600}.progress-container{flex-direction:column;gap:.5rem;display:flex}.progress-text{opacity:.8;justify-content:space-between;font-size:.85rem;font-weight:600;display:flex}.progress-bar{background:#0000000d;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--primary);height:100%;transition:width .5s ease-out}.add-item-sticky{background:var(--bg-gradient);z-index:100;margin-bottom:1rem;padding:.5rem 0 1rem;position:sticky;top:0}.add-item-form{gap:.5rem;margin-bottom:1rem;display:flex}.add-item-form input{border:1px solid var(--glass-border);background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;flex:1;padding:1rem;font-family:inherit;font-size:1rem}.add-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:16px;width:50px;font-size:1.5rem}.category-scroll{scrollbar-width:none;gap:.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.category-scroll::-webkit-scrollbar{display:none}.cat-pill{white-space:nowrap;border:1px solid var(--glass-border);background:var(--card-bg);color:var(--text);cursor:pointer;border-radius:50px;padding:.5rem 1rem;font-size:.8rem;font-weight:600;transition:all .3s}.cat-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.category-group{margin-bottom:2rem}.category-title{opacity:.9;margin-bottom:1rem;font-size:1.1rem}.items-grid{flex-direction:column;gap:.75rem;display:flex}.shopping-item{background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:16px;justify-content:space-between;align-items:center;padding:1rem;transition:all .3s;display:flex}.shopping-item.checked{opacity:.6;background:#fff6}.checkbox-container{cursor:pointer;flex:1;align-items:center;gap:1rem;display:flex}.checkbox-container input{display:none}.checkmark{border:2px solid var(--primary);border-radius:6px;width:24px;height:24px;transition:all .2s;position:relative}.checkbox-container input:checked+.checkmark{background:var(--primary)}.checkbox-container input:checked+.checkmark:after{content:"✓";color:#fff;font-weight:900;position:absolute;top:-2px;left:4px}.item-name{font-size:1rem;font-weight:500;transition:all .2s}.checked .item-name{text-decoration:line-through}.delete-item-btn{color:#ccc;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:1.2rem}.delete-item-btn:hover{color:#ff4081}.empty-state{text-align:center;opacity:.6;flex-direction:column;align-items:center;gap:1rem;padding:4rem 1rem;display:flex}.board-container{background-image:radial-gradient(#d7ccc8 1px,#0000 1px),radial-gradient(#d7ccc8 1px,#0000 1px);background-position:0 0,10px 10px;background-size:20px 20px;min-height:calc(100vh - 150px);padding-bottom:4rem}.board-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.5rem;padding:1rem 0;display:grid}.board-note{aspect-ratio:1;cursor:default;flex-direction:column;justify-content:space-between;padding:1.25rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;box-shadow:2px 4px 10px #0000001a}.board-note:hover{z-index:10;box-shadow:5px 10px 20px #00000026;transform:rotate(0)scale(1.05)translateY(-5px)!important}.board-note.pinned{border:1px solid #c9748f33;box-shadow:0 0 15px #c9748f4d}.pin-icon{filter:drop-shadow(0 2px 2px #0003);font-size:1.2rem;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.note-text{color:var(--text);-webkit-line-clamp:5;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.4;display:-webkit-box;overflow:hidden}.note-footer{border-top:1px solid #0000000d;justify-content:space-between;align-items:center;margin-top:.5rem;padding-top:.5rem;display:flex}.note-author{opacity:.7;font-size:.7rem;font-weight:600}.note-actions{gap:.25rem;display:flex}.note-actions button{cursor:pointer;opacity:.3;background:0 0;border:none;padding:2px;font-size:.8rem;transition:opacity .2s}.board-note:hover .note-actions button{opacity:1}.note-textarea{resize:none;background:#f9f9f9;border:1px solid #eee;border-radius:12px;width:100%;padding:1rem;font-family:inherit}.author-selection,.color-selection{flex-wrap:wrap;gap:.5rem;display:flex}.author-pill{cursor:pointer;background:#f5f5f5;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;transition:all .2s;display:flex}.author-pill.active{border-color:var(--primary);background:#fff;transform:scale(1.1)}.color-circle{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:all .2s}.color-circle.active{border-color:var(--primary);transform:scale(1.2)}.checkbox-row{align-items:center;display:flex}.tree-page{padding-bottom:5rem}.tree-visual{flex-direction:column;align-items:center;width:100%;margin-top:2rem;display:flex}.generation-row{justify-content:center;gap:1.5rem;margin-bottom:1rem;display:flex}.main-connector{flex-direction:column;align-items:center;width:100%;display:flex}.line-v{background:var(--primary);opacity:.3;width:2px;height:30px}.line-v.mini{height:15px}.line-h{background:var(--primary);opacity:.3;width:60%;height:2px}.branches-container{justify-content:center;gap:2rem;width:100%;padding-top:1rem;display:flex}.tree-branch{flex-direction:column;align-items:center;display:flex}.family-cell{padding:.5rem;position:relative}.cell-wrapper{flex-direction:column;align-items:center;gap:.75rem;display:flex}.couple-row{gap:1rem;display:flex}.cell-children{flex-direction:column;align-items:center;display:flex}.children-grid{gap:.5rem;display:flex}.members-row{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.member-card{background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);text-align:center;min-width:130px;box-shadow:var(--shadow);border-radius:20px;flex-direction:column;align-items:center;padding:1rem;transition:all .3s;display:flex}.member-card.compact{min-width:100px;padding:.75rem}.member-card.compact .member-avatar{font-size:1.75rem}.member-card.compact .member-info h3{font-size:.85rem}.member-card.compact .member-info p{font-size:.65rem}.member-card:hover{transform:translateY(-5px)}.member-avatar{margin-bottom:.5rem;font-size:2.5rem}.member-info h3{margin-bottom:.1rem;font-size:1rem}.member-info p{opacity:.7;color:var(--primary);font-size:.7rem;font-weight:600}.birth-year{opacity:.5;margin-top:.25rem;font-size:.65rem;display:block}.member-card.father{border-top:4px solid #4a90e2}.member-card.mother{border-top:4px solid #e24a90}.member-card.son{border-top:4px solid #4ae290}.member-card.daughterInLaw{border-top:4px solid #e2904a}.member-card.daughter{border-top:4px solid #904ae2}.member-card.granddaughter{border-top:4px solid #f39c12}@media (width<=768px){.branches-container{flex-direction:column;align-items:center}.line-h{width:2px;height:30px}}
