.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:linear-gradient(160deg,var(--color-warm-white) 0%,var(--color-warm-beige) 100%)}.login-container{width:100%;max-width:420px;padding:var(--space-10);background:var(--color-warm-white);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-header h1{font-family:var(--font-serif);font-size:2.25rem;font-weight:400;color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.01em}.login-header .subtitle{font-family:var(--font-sans);color:var(--color-text-muted);font-size:1rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:.875rem;color:var(--color-text-secondary);font-weight:500}.form-group input{padding:var(--space-4);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--color-sunset);box-shadow:var(--shadow-glow);background:var(--color-warm-white)}.form-group input::placeholder{color:var(--color-text-muted)}.error-message{padding:var(--space-4);background:var(--color-error-bg);border:1px solid rgba(201,85,61,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;text-align:center}.login-button{margin-top:var(--space-2);padding:var(--space-4) var(--space-6);background:var(--color-sunset);color:#fff;border-radius:var(--radius-md);font-size:1rem;font-weight:600;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.login-button:hover:not(:disabled){background:var(--color-sunset-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:var(--space-8);text-align:center}.login-footer p{font-family:var(--font-serif);font-style:italic;color:var(--color-text-muted);font-size:.9375rem}.login-container:before{content:"";display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--color-sunset),var(--color-blush));border-radius:var(--radius-full);margin:0 auto var(--space-6)}.upload-overlay{position:fixed;inset:0;background:#2c2c2c66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:var(--space-5);animation:fadeIn var(--transition-normal) ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(min-width:640px){.upload-overlay{align-items:center}}.upload-modal{width:100%;max-width:520px;max-height:90vh;background:var(--color-warm-white);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid var(--color-border-light);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;animation:slideUp var(--transition-normal) ease}@media(min-width:640px){.upload-modal{border-radius:var(--radius-xl)}}.upload-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light)}.upload-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400}.close-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.5rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.close-button:hover{background:var(--color-warm-beige);color:var(--color-text-secondary)}.upload-content{flex:1;overflow-y:auto;padding:var(--space-6)}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-12) var(--space-6);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--color-warm-cream)}.drop-zone:hover{border-color:var(--color-sunset);background:var(--color-sunset-light)}.drop-icon{width:72px;height:72px;background:var(--color-warm-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--space-5);box-shadow:var(--shadow-sm)}.drop-zone p{color:var(--color-text-secondary);font-weight:500;margin-bottom:var(--space-2)}.drop-hint{color:var(--color-text-muted);font-size:.875rem}.selected-files{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-6)}.file-preview{width:88px;position:relative}.file-preview img,.file-preview video{width:88px;height:88px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.file-icon{width:88px;height:88px;background:var(--color-warm-beige);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:2rem}.file-name{display:block;font-size:.6875rem;color:var(--color-text-muted);margin-top:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--color-border);border-radius:0 0 var(--radius-md) var(--radius-md);overflow:hidden}.progress-bar{height:100%;background:var(--color-sunset);transition:width var(--transition-fast)}.form-section{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.title-input,.description-input{width:100%;padding:var(--space-4);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem;transition:all var(--transition-fast)}.title-input:focus,.description-input:focus{outline:none;border-color:var(--color-sunset);box-shadow:var(--shadow-glow);background:var(--color-warm-white)}.title-input::placeholder,.description-input::placeholder{color:var(--color-text-muted)}.description-input{min-height:100px;resize:vertical;line-height:1.5}.unlock-section{margin-bottom:var(--space-6)}.unlock-section h3{font-family:var(--font-serif);font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-4);font-weight:400}.unlock-options{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.unlock-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal)}.unlock-option input{display:none}.unlock-option:hover{border-color:var(--color-tan);background:var(--color-warm-beige)}.unlock-option.active{border-color:var(--color-sunset);background:var(--color-sunset-light)}.option-icon{font-size:1.5rem}.unlock-option span:last-child{font-size:.75rem;color:var(--color-text-secondary);font-weight:500}.unlock-config{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--color-warm-cream);border-radius:var(--radius-md)}.unlock-config label{font-size:.875rem;color:var(--color-text-muted)}.unlock-config select,.unlock-config input[type=date]{padding:var(--space-3) var(--space-4);background:var(--color-warm-white);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem}.unlock-config select:focus,.unlock-config input[type=date]:focus{outline:none;border-color:var(--color-sunset);box-shadow:var(--shadow-glow)}.upload-button{width:100%;padding:var(--space-4) var(--space-6);background:var(--color-sunset);color:#fff;border-radius:var(--radius-md);font-size:1rem;font-weight:600;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.upload-button:hover:not(:disabled){background:var(--color-sunset-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.upload-button:disabled{opacity:.6;cursor:not-allowed}.upload-error{padding:var(--space-4);background:var(--color-error-bg);border:1px solid rgba(201,85,61,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;text-align:center;margin-bottom:var(--space-4)}.upload-options{display:flex;flex-direction:column;gap:var(--space-3)}.upload-option-btn{display:flex;align-items:center;gap:var(--space-4);width:100%;padding:var(--space-4) var(--space-5);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;transition:all var(--transition-normal)}.upload-option-btn:hover{background:var(--color-warm-beige);border-color:var(--color-sunset)}.upload-option-btn:active{transform:scale(.98)}.upload-option-btn .option-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-warm-white);border-radius:var(--radius-md)}.upload-option-btn .option-label{font-size:1rem;font-weight:500;color:var(--color-text-primary)}.drop-zone-compact{padding:var(--space-4);text-align:center;border:1px dashed var(--color-border);border-radius:var(--radius-md);margin-top:var(--space-2)}.drop-zone-compact p{font-size:.875rem;color:var(--color-text-muted);margin:0}.add-more-btn{width:88px;height:88px;display:flex;align-items:center;justify-content:center;background:var(--color-warm-cream);border:2px dashed var(--color-border);border-radius:var(--radius-md);font-size:2rem;color:var(--color-text-muted);transition:all var(--transition-fast)}.add-more-btn:hover{border-color:var(--color-sunset);color:var(--color-sunset)}.tags-section{margin-bottom:var(--space-6)}.tags-section h3{font-family:var(--font-serif);font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-4);font-weight:400}.special-tags,.custom-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.tag-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.tag-chip:hover{border-color:var(--color-sunset);background:var(--color-sunset-light)}.tag-chip.selected{background:var(--color-sunset);border-color:var(--color-sunset);color:#fff}.tag-chip.special .tag-icon{font-size:1rem}.tag-chip.custom{background:var(--color-blush-light);border-color:var(--color-blush)}.tag-chip.custom.selected{background:var(--color-blush);color:#fff}.tag-remove{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:#ffffff4d;border:none;border-radius:50%;color:inherit;font-size:.75rem;cursor:pointer;margin-left:var(--space-1)}.tag-remove:hover{background:#ffffff80}.add-tag-row{display:flex;gap:var(--space-2)}.tag-input{flex:1;padding:var(--space-2) var(--space-3);background:var(--color-warm-cream);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.875rem}.tag-input:focus{outline:none;border-color:var(--color-sunset);background:var(--color-warm-white)}.tag-input::placeholder{color:var(--color-text-muted)}.add-tag-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-sunset);border:none;border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast)}.add-tag-btn:hover:not(:disabled){background:var(--color-sunset-hover)}.add-tag-btn:disabled{background:var(--color-border);cursor:not-allowed}.memory-card{aspect-ratio:1;background:var(--color-warm-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden;position:relative;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.memory-card.unlocked{cursor:pointer}.memory-card.unlocked:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.memory-card.locked{cursor:default}.card-content{width:100%;height:100%;display:flex;flex-direction:column}.card-image,.card-video{width:100%;height:100%;object-fit:cover}.card-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-warm-cream) 0%,var(--color-warm-beige) 100%);font-size:3rem}.card-title{position:absolute;bottom:36px;left:0;right:0;padding:var(--space-3) var(--space-4);background:linear-gradient(transparent,#2c2c2cb3);color:#fff;font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.locked-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);background:linear-gradient(135deg,var(--color-warm-beige) 0%,var(--color-soft-gold) 100%);padding:var(--space-4)}.lock-icon{width:48px;height:48px;background:var(--color-warm-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-sm)}.lock-info{font-family:var(--font-serif);font-size:.8125rem;color:var(--color-text-secondary);text-align:center;font-style:italic}.card-meta{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-warm-white);border-top:1px solid var(--color-border-light)}.card-date{font-size:.6875rem;color:var(--color-text-muted)}.card-type{font-size:.875rem}.memory-modal{position:fixed;inset:0;background:#2c2c2ce6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:300;padding:var(--space-6);animation:fadeIn var(--transition-normal) ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-content{max-width:90vw;max-height:90vh;position:relative;display:flex;flex-direction:column;align-items:center;animation:scaleIn var(--transition-normal) ease}.modal-close{position:absolute;top:-48px;right:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;background:#ffffff1a;border-radius:50%;transition:all var(--transition-fast)}.modal-close:hover{background:#fff3}.modal-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.modal-video{max-width:100%;max-height:70vh;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.modal-audio{width:100%;max-width:400px;margin-top:var(--space-6)}.modal-info{margin-top:var(--space-6);text-align:center;max-width:500px;color:#fff}.modal-info h2{font-family:var(--font-serif);font-size:1.5rem;margin-bottom:var(--space-3);color:#fff}.modal-info p{color:#fffc;margin-bottom:var(--space-4);line-height:1.6}.modal-meta{display:flex;gap:var(--space-4);justify-content:center;font-size:.875rem;color:#fff9}.memory-card.unlocked:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(232,148,74,.1) 100%);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.memory-card.unlocked:hover:after{opacity:1}.memory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-5)}@media(min-width:640px){.memory-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-6)}}@media(min-width:1024px){.memory-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}.instructions-page{min-height:100vh;background:var(--color-warm-white)}.instructions-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--color-warm-white);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:100}.back-button{padding:var(--space-2) var(--space-3);color:var(--color-sunset);font-size:1rem;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.back-button:hover{background:var(--color-sunset-light)}.instructions-header h1{font-family:var(--font-serif);font-size:1.25rem;font-weight:400}.instructions-content{max-width:600px;margin:0 auto;padding:var(--space-6);padding-bottom:var(--space-12)}.instruction-section{margin-bottom:var(--space-8)}.instruction-section h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;color:var(--color-text-primary);margin-bottom:var(--space-3)}.instruction-section p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-3)}.instruction-section ul,.instruction-section ol{color:var(--color-text-secondary);line-height:1.7;padding-left:var(--space-6);margin-bottom:var(--space-3)}.instruction-section li{margin-bottom:var(--space-2)}.instruction-section strong{color:var(--color-text-primary);font-weight:600}.instruction-steps{display:flex;flex-direction:column;gap:var(--space-4)}.step{background:var(--color-warm-cream);border-radius:var(--radius-md);padding:var(--space-4)}.step-platform{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-sunset);margin-bottom:var(--space-2)}.step ol{margin-bottom:0}.instruction-note{background:var(--color-blush-light);border-radius:var(--radius-md);padding:var(--space-4);font-style:italic;color:var(--color-text-secondary)}.instruction-section:first-child{text-align:center;padding:var(--space-6);background:linear-gradient(135deg,var(--color-warm-cream) 0%,var(--color-warm-beige) 100%);border-radius:var(--radius-lg);margin-bottom:var(--space-8)}.instruction-section:first-child h2{font-size:1.5rem;margin-bottom:var(--space-4)}.instruction-section:first-child p{margin-bottom:0}.fionas-corner{position:fixed;inset:0;background:linear-gradient(180deg,#fff5f8,#fff0e5,#f0f8ff);z-index:1000;overflow-y:auto;display:flex;flex-direction:column;min-height:100vh}.fiona-exit-btn{position:fixed;top:var(--space-4);right:var(--space-4);width:48px;height:48px;background:#ffffffe6;border:2px solid #ddd;border-radius:50%;font-size:1.5rem;color:#999;display:flex;align-items:center;justify-content:center;z-index:1001;box-shadow:0 2px 8px #0000001a}.fiona-exit-btn:hover{background:#fff;color:#666}.fiona-home{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-8)}.fiona-welcome{text-align:center;animation:gentle-bounce 2s ease-in-out infinite}@keyframes gentle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.fiona-star{font-size:4rem;display:block;margin-bottom:var(--space-4);animation:sparkle 1.5s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(10deg)}}.fiona-welcome h1{font-family:var(--font-serif);font-size:3rem;color:#e8944a;margin-bottom:var(--space-2);text-shadow:2px 2px 0 rgba(255,255,255,.8)}.fiona-welcome p{font-size:1.25rem;color:#888}.fiona-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);max-width:600px;width:100%;padding:var(--space-4)}.fiona-menu-btn{aspect-ratio:1;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);border:4px solid transparent;transition:all .2s ease;box-shadow:0 8px 24px #0000001a}.fiona-menu-btn:active{transform:scale(.95)}.fiona-menu-btn.stories{background:linear-gradient(135deg,#ffe4b5,gold);border-color:#f5c842}.fiona-menu-btn.videos{background:linear-gradient(135deg,#e0f7fa,#80deea);border-color:#4dd0e1}.fiona-menu-btn.games{background:linear-gradient(135deg,#e8f5e9,#a5d6a7);border-color:#66bb6a}.fiona-menu-btn.memories{background:linear-gradient(135deg,#fce4ec,#f8bbd9);border-color:#f48fb1}.fiona-menu-btn.create-image{background:linear-gradient(135deg,#ede7f6,#d1c4e9);border-color:#b39ddb}.menu-icon{font-size:4rem}.menu-label{font-size:1.25rem;font-weight:700;color:#444}.fiona-call-family{display:flex;gap:var(--space-4);width:100%;max-width:400px;padding:var(--space-4)}.fiona-call-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:50px;text-decoration:none;font-weight:700;font-size:1.125rem;box-shadow:0 6px 20px #00000026;transition:all .2s ease}.fiona-call-btn:active{transform:scale(.95)}.fiona-call-btn.uncle{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.fiona-call-btn.grandma{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.call-icon{font-size:1.5rem}.call-label{font-size:1rem}.fiona-section{flex:1;display:flex;flex-direction:column;padding:var(--space-6);padding-top:var(--space-8)}.fiona-section-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.fiona-back-btn{width:56px;height:56px;background:#fff;border:3px solid #ddd;border-radius:50%;font-size:2rem;color:#666;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.fiona-back-btn:active{transform:scale(.95);background:#f5f5f5}.fiona-section-header h2{font-family:var(--font-serif);font-size:2rem;color:#444}.fiona-content{flex:1}.fiona-story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-5)}.fiona-story-card{background:linear-gradient(135deg,#fff8e1,#ffecb3);border:4px solid #FFD54F;border-radius:20px;padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);box-shadow:0 6px 16px #ffc10733;transition:transform .2s ease}.fiona-story-card:active{transform:scale(.95)}.story-icon{font-size:3rem}.story-title{font-size:1.125rem;font-weight:600;color:#444;text-align:center}.story-from{font-size:.875rem;color:#888}.fiona-video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-5)}.fiona-video-card{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:4px solid #64B5F6;border-radius:20px;padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);box-shadow:0 6px 16px #2196f333}.fiona-video-card.locked{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border-color:#bdbdbd}.video-icon{font-size:3rem}.video-title{font-size:1.125rem;font-weight:600;color:#444}.video-hint{font-size:.875rem;color:#888;text-align:center}.fiona-game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-5)}.fiona-game-card{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:4px solid #81C784;border-radius:20px;padding:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);box-shadow:0 6px 16px #4caf5033}.fiona-game-card.locked{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border-color:#bdbdbd}.game-icon{font-size:3rem}.game-title{font-size:1.125rem;font-weight:600;color:#444}.game-hint{font-size:.875rem;color:#888;text-align:center}.fiona-memory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-5)}.fiona-memory-card{background:linear-gradient(135deg,#fce4ec,#f8bbd9);border:4px solid #F48FB1;border-radius:20px;padding:var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);box-shadow:0 6px 16px #e91e6326;transition:transform .2s ease}.fiona-memory-card:active{transform:scale(.95)}.memory-icon{font-size:2.5rem}.memory-title{font-size:1rem;font-weight:600;color:#444;text-align:center}.memory-from{font-size:.75rem;color:#888}.fiona-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.fiona-empty .empty-icon{font-size:5rem;margin-bottom:var(--space-4);opacity:.8}.fiona-empty p{font-size:1.5rem;color:#666;margin-bottom:var(--space-2)}.fiona-empty .empty-hint{font-size:1rem;color:#999}.fiona-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);background:#ffffff80;margin-top:auto}.footer-star{font-size:1.5rem}.footer-text{font-family:var(--font-serif);font-size:1.25rem;color:#e8944a;font-weight:500}.fiona-watching{height:100%}.fiona-video-player{flex:1;display:flex;align-items:center;justify-content:center;background:#000;border-radius:20px;overflow:hidden;margin:var(--space-4);min-height:300px}.fiona-video-player iframe{width:100%;height:100%;min-height:400px}.video-external{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);width:100%;height:100%}.video-external .external-icon{font-size:5rem;margin-bottom:var(--space-4)}.video-external p{font-size:1.25rem;color:#444;margin-bottom:var(--space-4)}.open-youtube-btn{display:inline-block;padding:var(--space-4) var(--space-8);background:red;color:#fff;font-size:1.25rem;font-weight:600;border-radius:50px;text-decoration:none;box-shadow:0 4px 16px #ff00004d}.open-youtube-btn:active{transform:scale(.95)}@media(min-width:768px){.fiona-video-player{margin:var(--space-6)}.fiona-video-player iframe{min-height:500px}}@media(max-width:480px){.fiona-menu{gap:var(--space-3)}.fiona-menu-btn{padding:var(--space-3);border-radius:16px}.menu-icon{font-size:2.5rem}.menu-label{font-size:.875rem}.fiona-welcome h1{font-size:2rem}.fiona-section-header h2{font-size:1.5rem}.fiona-call-family{max-width:300px}.fiona-call-btn{padding:var(--space-3) var(--space-4)}.call-label{font-size:.875rem}}.fiona-create-image .fiona-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.create-image-content{width:100%;max-width:600px;padding:var(--space-4)}.image-prompt-intro{text-align:center;margin-bottom:var(--space-6)}.intro-icon{font-size:4rem;display:block;margin-bottom:var(--space-3);animation:wand-wave 2s ease-in-out infinite}@keyframes wand-wave{0%,to{transform:rotate(-10deg)}50%{transform:rotate(10deg)}}.image-prompt-intro p{font-size:1.5rem;color:#444;font-weight:500}.prompt-suggestions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.prompt-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-5);background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:3px solid #81C784;border-radius:16px;transition:all .2s ease;box-shadow:0 4px 12px #0000001a}.prompt-btn:nth-child(2){background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#64b5f6}.prompt-btn:nth-child(3){background:linear-gradient(135deg,#fff3e0,#ffcc80);border-color:#ffb74d}.prompt-btn:nth-child(4){background:linear-gradient(135deg,#f3e5f5,#ce93d8);border-color:#ba68c8}.prompt-btn:nth-child(5){background:linear-gradient(135deg,#e0f7fa,#80deea);border-color:#4dd0e1}.prompt-btn:nth-child(6){background:linear-gradient(135deg,#fce4ec,#f8bbd9);border-color:#f48fb1}.prompt-btn:nth-child(7){background:linear-gradient(135deg,#fff8e1,#ffe082);border-color:#ffd54f}.prompt-btn:nth-child(8){background:linear-gradient(135deg,#ffebee,#ffcdd2);border-color:#ef9a9a}.prompt-btn:active{transform:scale(.95)}.prompt-emoji{font-size:2.5rem}.prompt-label{font-size:1rem;font-weight:600;color:#444}.generating-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.magic-wand{font-size:5rem;animation:magic-pulse 1s ease-in-out infinite}@keyframes magic-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.generating-text{font-size:1.5rem;color:#444;margin:var(--space-4) 0}.generating-spinner{width:60px;height:60px;border:6px solid #E8E8E8;border-top:6px solid #B39DDB;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generated-result{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);width:100%}.generated-image-container{width:100%;max-width:400px;border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #00000026;border:4px solid #B39DDB}.generated-image{width:100%;height:auto;display:block}.result-prompt{font-size:1.125rem;color:#666;text-align:center;font-style:italic}.create-another-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,#ede7f6,#d1c4e9);border:3px solid #B39DDB;border-radius:50px;font-size:1.25rem;font-weight:600;color:#5e35b1;box-shadow:0 4px 16px #9575cd4d;margin-top:var(--space-4)}.create-another-btn:active{transform:scale(.95)}.image-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:#fff3e0;border:2px solid #FFB74D;border-radius:12px;color:#e65100;font-size:1rem;margin-bottom:var(--space-4);justify-content:center}@media(min-width:768px){.fiona-menu{max-width:700px;gap:var(--space-6)}.fiona-menu-btn{padding:var(--space-6)}.menu-icon{font-size:4rem}.menu-label{font-size:1.25rem}.fiona-welcome h1{font-size:3rem}.fiona-call-family{max-width:500px}.fiona-story-grid,.fiona-video-grid,.fiona-game-grid,.fiona-memory-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.prompt-suggestions{grid-template-columns:repeat(4,1fr)}.prompt-btn{padding:var(--space-6)}.prompt-emoji{font-size:3rem}.generated-image-container{max-width:500px}}.moms-corner{position:fixed;inset:0;background:var(--color-warm-white);z-index:1000;overflow-y:auto;display:flex;flex-direction:column}.moms-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:#fff;border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:10}.back-btn{width:44px;height:44px;background:var(--color-warm-cream);border:none;border-radius:50%;font-size:1.25rem;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center}.back-btn:hover{background:var(--color-warm-beige)}.header-title{display:flex;align-items:center;gap:var(--space-3)}.header-icon{font-size:1.75rem}.header-title h1{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary)}.moms-content{flex:1;padding:var(--space-6);max-width:800px;margin:0 auto;width:100%}.manage-section{background:#fff;border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm)}.section-header{margin-bottom:var(--space-5)}.section-header h2{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);margin-bottom:var(--space-1)}.section-header p{font-size:.875rem;color:var(--color-text-muted)}.empty-channels{text-align:center;padding:var(--space-8);background:var(--color-warm-cream);border-radius:var(--radius-md)}.empty-channels .empty-icon{font-size:3rem;display:block;margin-bottom:var(--space-3)}.empty-channels p{color:var(--color-text-secondary);margin-bottom:var(--space-1)}.empty-channels .hint{font-size:.875rem;color:var(--color-text-muted)}.channel-list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.channel-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-warm-cream);border-radius:var(--radius-md);transition:all var(--transition-fast)}.channel-card:hover{background:var(--color-warm-beige)}.channel-emoji{font-size:2rem;width:48px;height:48px;background:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.channel-info{flex:1;min-width:0}.channel-name{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.channel-url{display:block;font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remove-btn{width:32px;height:32px;background:transparent;border:none;border-radius:50%;font-size:1.25rem;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer}.remove-btn:hover{background:#dc35451a;color:#dc3545}.add-channel-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-4);background:var(--color-sunset-light);color:var(--color-sunset);border:2px dashed var(--color-sunset);border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer;transition:all var(--transition-fast)}.add-channel-btn:hover{background:var(--color-sunset);color:#fff;border-style:solid}.add-channel-btn span{font-size:1.25rem}.add-form{background:var(--color-warm-cream);border-radius:var(--radius-md);padding:var(--space-5)}.add-form h3{font-family:var(--font-serif);font-size:1.125rem;color:var(--color-text-primary);margin-bottom:var(--space-4)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.form-group input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:1rem;background:#fff}.form-group input:focus{outline:none;border-color:var(--color-sunset);box-shadow:0 0 0 3px var(--color-sunset-light)}.form-group .hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-1)}.emoji-picker{display:flex;flex-wrap:wrap;gap:var(--space-2)}.emoji-btn{width:44px;height:44px;background:#fff;border:2px solid var(--color-border-light);border-radius:var(--radius-md);font-size:1.5rem;cursor:pointer;transition:all var(--transition-fast)}.emoji-btn:hover{border-color:var(--color-sunset)}.emoji-btn.selected{border-color:var(--color-sunset);background:var(--color-sunset-light)}.form-error{background:#fff5f5;color:#dc3545;padding:var(--space-3);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--space-4)}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.cancel-btn{padding:var(--space-3) var(--space-5);background:transparent;border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:500;cursor:pointer}.cancel-btn:hover{background:var(--color-warm-beige)}.save-btn{padding:var(--space-3) var(--space-5);background:var(--color-sunset);border:none;border-radius:var(--radius-md);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.save-btn:hover:not(:disabled){background:var(--color-sunset-hover)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.coming-soon-list{display:flex;flex-direction:column;gap:var(--space-3)}.coming-soon-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-warm-cream);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.9375rem}.coming-soon-item span{font-size:1.25rem}.feature-toggles{display:flex;flex-direction:column;gap:var(--space-3)}.feature-toggle{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-warm-cream);border-radius:var(--radius-md)}.feature-info{display:flex;align-items:center;gap:var(--space-4)}.feature-icon{font-size:2rem;width:48px;height:48px;background:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.feature-text{display:flex;flex-direction:column;gap:var(--space-1)}.feature-name{font-weight:600;color:var(--color-text-primary)}.feature-desc{font-size:.875rem;color:var(--color-text-muted)}.toggle-btn{width:56px;height:32px;border-radius:16px;border:none;cursor:pointer;position:relative;transition:background-color var(--transition-fast)}.toggle-btn.off{background:var(--color-border)}.toggle-btn.on{background:#4ade80}.toggle-slider{position:absolute;top:3px;width:26px;height:26px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;transition:left var(--transition-fast)}.toggle-btn.off .toggle-slider{left:3px}.toggle-btn.on .toggle-slider{left:27px}.uncs-corner{position:fixed;inset:0;background:var(--color-warm-white);z-index:1000;overflow-y:auto;display:flex;flex-direction:column}.uncs-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:#fff;border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:10}.uncs-corner .back-btn{width:44px;height:44px;background:var(--color-warm-cream);border:none;border-radius:50%;font-size:1.25rem;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center}.uncs-corner .back-btn:hover{background:var(--color-warm-beige)}.uncs-corner .header-title{display:flex;align-items:center;gap:var(--space-3)}.uncs-corner .header-icon{font-size:1.75rem}.uncs-corner .header-title h1{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary)}.uncs-content{flex:1;padding:var(--space-6);max-width:800px;margin:0 auto;width:100%}.admin-section{background:#fff;border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm)}.admin-section .section-header{margin-bottom:var(--space-5)}.admin-section .section-header h2{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);margin-bottom:var(--space-1)}.admin-section .section-header p{font-size:.875rem;color:var(--color-text-muted)}.loading-state{text-align:center;padding:var(--space-8);color:var(--color-text-muted)}.prompt-editor{margin-bottom:var(--space-4)}.prompt-editor textarea{width:100%;padding:var(--space-4);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:.9375rem;font-family:monospace;line-height:1.6;background:var(--color-warm-cream);resize:vertical;min-height:200px}.prompt-editor textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;background:#fff}.prompt-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.reset-btn{padding:var(--space-3) var(--space-5);background:transparent;border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:500;cursor:pointer}.reset-btn:hover{background:var(--color-warm-beige)}.uncs-corner .save-btn{padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:var(--radius-md);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.uncs-corner .save-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66}.uncs-corner .save-btn:disabled{opacity:.7;cursor:not-allowed}.info-cards{display:flex;flex-direction:column;gap:var(--space-3)}.info-card{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--color-warm-cream);border-radius:var(--radius-md)}.info-icon{font-size:1.5rem;flex-shrink:0}.info-text strong{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-1)}.info-text p{font-size:.875rem;color:var(--color-text-muted);margin:0}.status-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-light)}.status-row:last-of-type{border-bottom:none}.status-label{font-weight:500;color:var(--color-text-secondary)}.status-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.status-hint{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-3);font-style:italic}.home-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-warm-white)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--color-warm-white);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:var(--space-4)}.header-left h1{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;color:var(--color-text-primary)}.user-badge{padding:var(--space-1) var(--space-3);background:var(--color-sunset-light);border-radius:var(--radius-full);font-size:.75rem;color:var(--color-sunset);font-weight:500;text-transform:capitalize}.header-right{display:flex;align-items:center;gap:var(--space-2)}.help-button{padding:var(--space-2) var(--space-4);color:var(--color-sunset);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.help-button:hover{background:var(--color-sunset-light)}.logout-button{padding:var(--space-2) var(--space-4);color:var(--color-text-muted);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.logout-button:hover{color:var(--color-text-secondary);background:var(--color-warm-beige)}.stats-bar{display:flex;justify-content:center;gap:var(--space-12);padding:var(--space-6) var(--space-6);background:var(--color-warm-cream);border-bottom:1px solid var(--color-border-light)}.stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-value{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--color-text-primary)}.stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.tab-bar{display:flex;justify-content:space-between;padding:0 var(--space-6);background:var(--color-warm-white);border-bottom:1px solid var(--color-border-light)}.tabs-left,.tabs-right{display:flex;gap:var(--space-2)}.tab{padding:var(--space-4) var(--space-5);color:var(--color-text-muted);font-size:.875rem;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast)}.tab:hover{color:var(--color-text-secondary)}.tab.active{color:var(--color-sunset);border-bottom-color:var(--color-sunset)}.tab-fiona{color:#e8944a;font-weight:600}.tab-fiona:hover{color:#d4802e}.tab-fiona.active{color:#e8944a;border-bottom-color:#e8944a}.tab-special{color:var(--color-blush)}.tab-special:hover{color:var(--color-blush-dark, #c97b8a)}.tab-special.active{color:var(--color-blush);border-bottom-color:var(--color-blush)}.main-content{flex:1;padding:var(--space-6);padding-bottom:100px;max-width:1200px;margin:0 auto;width:100%}.welcome-message{text-align:center;padding:var(--space-8) var(--space-6);margin-bottom:var(--space-6)}.welcome-message h2{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin-bottom:var(--space-2)}.welcome-message p{color:var(--color-text-muted);font-size:.9375rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);gap:var(--space-4)}.empty-icon{width:80px;height:80px;background:var(--color-blush-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin-bottom:var(--space-4)}.empty-state h2{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary)}.empty-state p{color:var(--color-text-muted);max-width:300px;line-height:1.6}.add-first-button{margin-top:var(--space-4);padding:var(--space-4) var(--space-8);background:var(--color-sunset);color:#fff;border-radius:var(--radius-md);font-weight:600;box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.add-first-button:hover{background:var(--color-sunset-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.corner-content{display:flex;flex-direction:column;align-items:center;padding:var(--space-12) var(--space-6)}.corner-header{text-align:center;margin-bottom:var(--space-8)}.corner-icon{font-size:4rem;display:block;margin-bottom:var(--space-4)}.corner-header h2{font-family:var(--font-serif);font-size:2rem;color:var(--color-text-primary);margin-bottom:var(--space-2)}.corner-header p{color:var(--color-text-muted);font-size:1rem}.corner-placeholder{background:var(--color-warm-cream);border:2px dashed var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-12) var(--space-8);text-align:center;width:100%;max-width:500px}.corner-placeholder p{color:var(--color-text-muted);font-style:italic}.fab{position:fixed;bottom:var(--space-6);right:var(--space-6);width:56px;height:56px;background:var(--color-sunset);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:300;box-shadow:var(--shadow-lg);transition:all var(--transition-normal);z-index:50}.fab:hover{background:var(--color-sunset-hover);transform:scale(1.05);box-shadow:0 8px 24px #e8944a59}.fab:active{transform:scale(.98)}.fab span{line-height:1;margin-top:-2px}@supports (padding: env(safe-area-inset-bottom)){.fab{bottom:calc(var(--space-6) + env(safe-area-inset-bottom))}}@media(max-width:640px){.stats-bar{gap:var(--space-8);padding:var(--space-5)}.stat-value{font-size:1.5rem}.header-left h1{font-size:1.25rem}}:root{--color-warm-white: #FFFBF7;--color-warm-cream: #FAF8F5;--color-warm-beige: #F5F1ED;--color-soft-gold: #E8DCC4;--color-tan: #D4C5B0;--color-sunset: #E8944A;--color-sunset-hover: #D4843A;--color-sunset-light: rgba(232, 148, 74, .1);--color-teal: #6BA9A4;--color-teal-light: rgba(107, 169, 164, .1);--color-blush: #E8B4A8;--color-blush-light: rgba(232, 180, 168, .15);--color-sage: #A8B8A0;--color-text-primary: #2C2C2C;--color-text-secondary: #3A3A3A;--color-text-muted: #7A7A7A;--color-border: #D9D3CC;--color-border-light: #E8E4DE;--color-error: #C9553D;--color-error-bg: #FDF3F1;--color-success: #5A8A5E;--color-success-bg: #F3F8F3;--shadow-sm: 0 1px 3px rgba(44, 44, 44, .06), 0 1px 2px rgba(44, 44, 44, .04);--shadow-md: 0 4px 12px rgba(44, 44, 44, .08), 0 2px 4px rgba(44, 44, 44, .04);--shadow-lg: 0 12px 32px rgba(44, 44, 44, .12), 0 4px 8px rgba(44, 44, 44, .06);--shadow-glow: 0 0 0 3px rgba(232, 148, 74, .15);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-serif: "Cardo", Georgia, "Times New Roman", serif;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .4s ease}*{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{height:100%;font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--color-text-primary);background:var(--color-warm-white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;min-height:100vh}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;line-height:1.3;color:var(--color-text-primary)}h1{font-size:2.5rem;letter-spacing:-.02em}h2{font-size:1.75rem}h3{font-size:1.25rem}p{color:var(--color-text-secondary)}input,textarea,select,button{font-family:var(--font-sans);font-size:1rem}button{cursor:pointer;border:none;background:none;transition:all var(--transition-normal)}a{color:var(--color-sunset);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-sunset-hover)}:focus-visible{outline:2px solid var(--color-sunset);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-warm-cream)}::-webkit-scrollbar-thumb{background:var(--color-tan);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-soft-gold)}::selection{background:var(--color-sunset-light);color:var(--color-text-primary)}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-warm-white)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-sunset);border-radius:50%;animation:spin .8s linear infinite}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}.text-serif{font-family:var(--font-serif)}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}
