@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap);.auth-container{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.auth-background{inset:0;position:absolute;z-index:0}.auth-orb{border-radius:50%;filter:blur(80px);opacity:.5;position:absolute}.auth-orb-1{animation:float 8s ease-in-out infinite;background:linear-gradient(135deg,#8b5cf6,#6366f1);height:400px;right:-100px;top:-100px;width:400px}.auth-orb-2{animation:float 10s ease-in-out infinite reverse;background:linear-gradient(135deg,#06b6d4,#0ea5e9);bottom:-50px;height:300px;left:-50px;width:300px}.auth-orb-3{animation:float 12s ease-in-out infinite;background:linear-gradient(135deg,#f43f5e,#ec4899);height:250px;left:30%;top:50%;width:250px}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a24cc;border:1px solid #ffffff1a;border-radius:24px;margin:20px;max-width:420px;padding:40px;position:relative;width:100%;z-index:1}.auth-logo{margin-bottom:32px;text-align:center}.auth-logo .logo-icon{display:block;font-size:48px;margin-bottom:16px}.auth-logo h1{color:#fff;font-family:Playfair Display,Georgia,serif;font-size:28px;font-weight:600;margin:0 0 8px}.auth-logo p{color:#ffffff80;font-size:14px;margin:0}.auth-form h2{color:#fff;font-size:22px;font-weight:600;margin:0 0 24px;text-align:center}.auth-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;color:#fca5a5;font-size:14px;padding:12px 16px;text-align:center}.auth-error,.auth-form .form-group{margin-bottom:20px}.auth-form label{color:#ffffffb3;display:block;font-size:13px;font-weight:500;margin-bottom:8px}.auth-form input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-size:15px;outline:none;padding:14px 18px;transition:all .2s;width:100%}.auth-form input::placeholder{color:#ffffff4d}.auth-form input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.auth-button{align-items:center;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:16px;transition:all .2s;width:100%}.auth-button:hover:not(:disabled){box-shadow:0 10px 20px -5px #8b5cf666;transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.7}.auth-switch{color:#ffffff80;font-size:14px;margin-top:24px;text-align:center}.auth-switch a{color:#a78bfa;font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0f14cc;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:16px 32px}.header-brand{align-items:center;display:flex;gap:12px}.header-icon{font-size:28px}.header-brand h1{color:#fff;font-family:Playfair Display,Georgia,serif;font-size:22px;font-weight:600;margin:0}.header-user{align-items:center;display:flex;gap:16px}.user-greeting{color:#ffffffb3;font-size:14px}.btn-logout{background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;color:#fffc;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .2s}.btn-logout:hover{background:#ffffff26}.dashboard-main{flex:1 1;margin:0 auto;max-width:1200px;padding:40px 32px;width:100%}.welcome-section{margin-bottom:40px;text-align:center}.welcome-section h2{color:#fff;font-family:Playfair Display,Georgia,serif;font-size:32px;font-weight:600;margin:0 0 8px}.welcome-section p{color:#ffffff80;font-size:16px;margin:0}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 0}.loading-state p{color:#ffffff80;margin-top:16px}.circles-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.circle-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:20px;cursor:pointer;padding:28px;transition:all .2s}.circle-card:hover{background:#ffffff0d;border-color:#ffffff1f;transform:translateY(-4px)}.circle-card-new{border-color:#ffffff26;border-style:dashed}.circle-card-new:hover{background:#8b5cf60d;border-color:#8b5cf666}.circle-icon{font-size:40px;margin-bottom:16px}.circle-card h3{color:#fff;font-size:18px;font-weight:600;margin:0 0 8px}.circle-card p{color:#ffffff80;font-size:14px;line-height:1.5;margin:0 0 16px}.circle-meta{display:flex;gap:12px}.circle-meta span{color:#8b5cf6cc;font-size:12px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal-content{background:#1a1a24;border:1px solid #ffffff1a;border-radius:20px;max-width:420px;padding:32px;width:100%}.modal-content h2{color:#fff;font-size:22px;font-weight:600;margin:0 0 24px;text-align:center}.modal-content .form-group{margin-bottom:20px}.modal-content label{color:#ffffffb3;display:block;font-size:13px;font-weight:500;margin-bottom:8px}.modal-content input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-size:15px;outline:none;padding:14px 18px;transition:all .2s;width:100%}.modal-content input::placeholder{color:#ffffff4d}.modal-content input:focus{border-color:#8b5cf6}.modal-actions{display:flex;gap:12px;margin-top:28px}.modal-actions button{border-radius:12px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:14px;transition:all .2s}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:12px;padding:12px 20px}.dashboard-main{padding:24px 20px}.welcome-section h2{font-size:26px}.circles-grid{grid-template-columns:1fr}}.family-loading,.family-page{display:flex;flex-direction:column;min-height:100vh}.family-loading{align-items:center;justify-content:center}.family-loading p{color:#ffffff80;margin-top:16px}.family-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0f14cc;border-bottom:1px solid #ffffff1a;display:flex;gap:20px;padding:20px 32px}.btn-back{background:#ffffff1a;border:none;border-radius:10px;color:#fffc;cursor:pointer;font-size:14px;padding:10px 16px;transition:all .2s}.btn-back:hover{background:#ffffff26}.header-info h1{color:#fff;font-size:24px;font-weight:600;margin:0}.header-info p{color:#ffffff80;font-size:14px;margin:4px 0 0}.family-tabs{background:#0f0f1499;border-bottom:1px solid #ffffff0d;display:flex;gap:8px;padding:16px 32px}.tab{background:#0000;border:1px solid #ffffff1a;border-radius:12px;color:#fff9;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.tab:hover{background:#ffffff0d;color:#fffc}.tab.active{background:#8b5cf633;border-color:#8b5cf666;color:#a78bfa}.family-main{flex:1 1;margin:0 auto;max-width:900px;padding:32px;width:100%}.empty-state{padding:60px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.6}.empty-state h3{color:#fff;font-size:20px;margin:0 0 8px}.empty-state p{color:#ffffff80;margin:0 0 24px}.stories-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.stories-count{color:#ffffff80;font-size:14px}.btn-export-book{background:#22c55e1a;border:1px solid #22c55e33;border-radius:10px;color:#86efac;cursor:pointer;font-size:14px;font-weight:500;padding:10px 18px;transition:all .2s}.btn-export-book:hover{background:#22c55e33;border-color:#22c55e66}.stories-list{display:flex;flex-direction:column;gap:16px}.story-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;cursor:pointer;padding:24px;transition:all .2s}.story-card:hover{background:#ffffff0d;border-color:#ffffff1f}.story-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.story-header h3{color:#fff;font-size:17px;font-weight:600;margin:0}.story-badges{display:flex;flex-shrink:0;gap:8px}.badge-enhanced{background:#8b5cf626;color:#a78bfa}.badge-enhanced,.status-badge{border-radius:6px;font-size:11px;font-weight:600;padding:4px 10px}.status-badge{text-transform:uppercase}.status-complete{background:#22c55e26;color:#86efac}.status-transcribing{background:#eab30826;color:#fde047}.status-failed{background:#ef444426;color:#fca5a5}.story-preview{color:#fff9;font-size:14px;line-height:1.6;margin:0 0 16px}.story-meta{display:flex;gap:16px}.story-meta span{color:#fff6;font-size:12px}.story-audio{border-radius:8px;margin-top:16px;width:100%}.loading-audio{margin-top:12px}.record-tab{margin:0 auto;max-width:500px}.record-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;padding:32px}.record-card h2{color:#fff;font-size:22px;font-weight:600;margin:0 0 24px;text-align:center}.record-card .form-group{margin-bottom:24px}.record-card label{color:#ffffffb3;display:block;font-size:13px;font-weight:500;margin-bottom:8px}.record-card input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-size:15px;outline:none;padding:14px 18px;transition:all .2s;width:100%}.record-card input::placeholder{color:#ffffff4d}.record-card input:focus{border-color:#8b5cf6}.record-card input:disabled{opacity:.5}.recording-area{padding:32px 0;text-align:center}.recording-time{color:#fff;font-family:SF Mono,Monaco,Consolas,monospace;font-size:56px;font-weight:300;margin-bottom:8px}.recording-status{color:#ffffff80;font-size:14px;margin-bottom:24px}.btn-record{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:50%;box-shadow:0 8px 24px -4px #ef444466;cursor:pointer;display:flex;height:100px;justify-content:center;margin:0 auto;transition:all .2s;width:100px}.btn-record:hover:not(:disabled){transform:scale(1.05)}.btn-record:disabled{cursor:not-allowed;opacity:.5}.btn-record.recording{animation:pulse-record 1.5s infinite}@keyframes pulse-record{0%,to{box-shadow:0 0 0 0 #ef444480}50%{box-shadow:0 0 0 20px #ef444400}}.mic-icon{font-size:36px}.stop-icon{color:#fff;font-size:28px}.recording-preview{margin-top:24px}.recording-preview audio{border-radius:8px;margin-bottom:20px;width:100%}.preview-actions{display:flex;gap:12px}.recording-tip{background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:12px;color:#ffffffb3;font-size:13px;margin-top:24px;padding:16px;text-align:center}.members-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.member-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:14px;gap:16px;padding:16px 20px}.member-avatar,.member-card{align-items:center;display:flex}.member-avatar{background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:50%;color:#fff;font-size:20px;font-weight:600;height:48px;justify-content:center;width:48px}.member-info h4{color:#fff;font-size:15px;font-weight:600;margin:0 0 4px}.member-info p{color:#ffffff80;font-size:13px;margin:0;text-transform:capitalize}.btn-invite{background:#ffffff0d;border:1px dashed #fff3;border-radius:14px;color:#fff9;cursor:pointer;font-size:14px;font-weight:500;padding:16px;transition:all .2s;width:100%}.btn-invite:hover{background:#8b5cf61a;border-color:#8b5cf64d;color:#a78bfa}.voice-profiles-section{border-top:1px solid #ffffff1a;margin-top:32px;padding-top:32px}.voice-profiles-section h3{color:#fff;font-size:18px;font-weight:600;margin:0 0 8px}.section-description{color:#ffffff80;font-size:14px;margin:0 0 20px}.voice-profiles-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.voice-profile-card{align-items:center;background:#06b6d40d;border:1px solid #06b6d426;border-radius:14px;display:flex;gap:16px;padding:16px 20px}.voice-icon{font-size:24px}.voice-info h4{color:#fff;font-size:15px;font-weight:600;margin:0 0 4px}.voice-info p{color:#ffffff80;font-size:13px;margin:0}.no-voices{color:#fff6;font-size:14px;padding:20px;text-align:center}.btn-create-voice{background:linear-gradient(135deg,#06b6d4,#0ea5e9);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:14px;transition:all .2s;width:100%}.btn-create-voice:hover{box-shadow:0 8px 16px -4px #06b6d466;transform:translateY(-2px)}.badge-voice{background:#06b6d426;border-radius:6px;color:#67e8f9;font-size:11px;font-weight:600;padding:4px 10px}.file-input{background:#ffffff0d;border:1px dashed #fff3;border-radius:12px;color:#ffffffb3;cursor:pointer;font-size:14px;padding:12px;width:100%}.file-input:hover{border-color:#8b5cf666}.file-count{color:#8b5cf6cc;font-size:13px;margin-top:8px}.pending-invites-section{border-top:1px solid #ffffff1a;margin-top:24px;padding-top:24px}.pending-invites-section h3{color:#fff;font-size:16px;font-weight:600;margin:0 0 16px}.pending-invites-list{display:flex;flex-direction:column;gap:10px}.pending-invite-card{align-items:center;background:#fbbf240d;border:1px solid #fbbf2426;border-radius:12px;display:flex;justify-content:space-between;padding:14px 18px}.invite-info{flex:1 1}.invite-email{color:#fff;font-size:14px;font-weight:500;margin:0 0 4px}.invite-meta{color:#ffffff80;font-size:12px;margin:0}.btn-cancel-invite{background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#fca5a5;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s}.btn-cancel-invite:hover{background:#ef444433}.modal-content select{-webkit-appearance:none;appearance:none;background:#ffffff0d;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M8 11 3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border:1px solid #ffffff1a;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;outline:none;padding:14px 18px;width:100%}.modal-content select:focus{border-color:#8b5cf6}.modal-content select option{background:#1a1a24;color:#fff}@media (max-width:768px){.family-header{padding:16px 20px}.family-tabs{overflow-x:auto;padding:12px 20px}.family-main{padding:20px}.record-card{padding:24px 20px}.recording-time{font-size:44px}}.story-detail,.story-detail-error,.story-detail-loading{display:flex;flex-direction:column;min-height:100vh}.story-detail-error,.story-detail-loading{align-items:center;gap:16px;justify-content:center}.story-detail-error p,.story-detail-loading p{color:#ffffff80}.story-detail-header{align-items:flex-start;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0f14cc;border-bottom:1px solid #ffffff1a;display:flex;gap:20px;padding:24px 32px}.story-detail-header .btn-back{background:#ffffff1a;border:none;border-radius:10px;color:#fffc;cursor:pointer;flex-shrink:0;font-size:14px;padding:10px 16px;transition:all .2s}.story-detail-header .btn-back:hover{background:#ffffff26}.story-detail-header .header-info{flex:1 1}.story-detail-header h1{color:#fff;font-size:26px;font-weight:600;line-height:1.3;margin:0 0 8px}.story-meta-header{color:#ffffff80;display:flex;font-size:14px;gap:8px}.story-detail-main{flex:1 1;margin:0 auto;max-width:800px;padding:32px;width:100%}.audio-section{margin-bottom:24px}.audio-player{border-radius:12px;width:100%}.btn-load-audio{background:#ffffff1a;border:1px solid #ffffff26;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;padding:14px 24px;transition:all .2s}.btn-load-audio:hover:not(:disabled){background:#ffffff26}.btn-load-audio:disabled{cursor:not-allowed;opacity:.6}.version-tabs{background:#ffffff08;border-radius:14px;display:flex;gap:8px;margin-bottom:24px;padding:4px}.version-tab{background:#0000;border:none;border-radius:10px;color:#ffffff80;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px 16px;transition:all .2s}.version-tab:hover:not(:disabled){background:#ffffff0d;color:#fffc}.version-tab.active{background:#8b5cf633;color:#a78bfa}.version-tab:disabled{cursor:not-allowed;opacity:.3}.enhance-section{background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:16px;margin-bottom:24px;padding:24px;text-align:center}.btn-enhance{align-items:center;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;padding:16px 32px;transition:all .2s}.btn-enhance:hover:not(:disabled){box-shadow:0 10px 20px -5px #8b5cf666;transform:translateY(-2px)}.btn-enhance:disabled{cursor:wait;opacity:.8}.btn-enhance .spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.enhance-hint{color:#ffffff80;font-size:13px;margin:12px 0 0}.story-content{background:#ffffff08;border:1px solid #ffffff14;border-radius:20px;padding:32px}.literary-content p,.transcript-content p{color:#ffffffd9;font-size:16px;line-height:1.8;margin:0 0 20px}.literary-content p:last-child,.transcript-content p:last-child{margin-bottom:0}.literary-content{font-family:Playfair Display,Georgia,serif}.literary-content strong{color:#fff;display:block;font-size:22px;margin-bottom:24px;text-align:center}.story-metadata{background:#ffffff08;border-radius:12px;margin-top:24px;padding:20px}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tag{background:#8b5cf626;border-radius:20px;color:#a78bfa;font-size:12px;font-weight:500;padding:6px 12px}.people-mentioned{color:#fff9;font-size:13px}.people-mentioned strong{color:#fffc}@media (max-width:768px){.story-detail-header{flex-direction:column;gap:12px;padding:16px 20px}.story-detail-header h1{font-size:22px}.story-content,.story-detail-main{padding:20px}.version-tabs{flex-wrap:wrap}.version-tab{flex:none;font-size:13px;padding:10px 14px}}.audio-section-header{margin-bottom:12px}.audio-label{color:#ffffffb3;font-size:13px;font-weight:600}.synthesized-audio{background:#8b5cf60d;border:1px solid #8b5cf633;border-radius:12px;margin-bottom:24px;padding:16px}.synthesized-audio .audio-label{color:#a78bfa}.synth-badge{font-size:12px;margin-left:6px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.btn-synthesize{align-items:center;background:linear-gradient(135deg,#06b6d4,#0ea5e9);border:none;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:14px 24px;transition:all .2s}.btn-synthesize:hover:not(:disabled){box-shadow:0 10px 20px -5px #06b6d466;transform:translateY(-2px)}.btn-synthesize:disabled{cursor:not-allowed;opacity:.6}.no-voice-hint{background:#ffffff08;border:1px dashed #ffffff26;border-radius:12px;padding:16px 20px;width:100%}.no-voice-hint p{color:#ffffff80;font-size:14px;margin:0}.voice-modal{max-width:450px}.modal-description{color:#fff9;font-size:14px;line-height:1.5;margin-bottom:24px}.voice-modal select{-webkit-appearance:none;appearance:none;background:#ffffff0d;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M8 11 3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border:1px solid #ffffff1a;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;outline:none;padding:14px 18px;width:100%}.voice-modal select:focus{border-color:#8b5cf6}.voice-modal select option{background:#1a1a24;color:#fff}.loading-audio{color:#ffffff80;font-size:13px;padding:12px 0}.photos-section{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;margin-bottom:24px;padding:20px}.photos-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.photos-header h3{color:#fff;font-size:16px;font-weight:600;margin:0}.btn-add-photo{background:#8b5cf626;border:1px solid #8b5cf64d;border-radius:8px;color:#a78bfa;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-add-photo:hover{background:#8b5cf640}.photos-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.photo-thumb{aspect-ratio:1;border-radius:10px;cursor:pointer;overflow:hidden;transition:transform .2s}.photo-thumb:hover{transform:scale(1.05)}.photo-thumb img{height:100%;object-fit:cover;width:100%}.no-photos{color:#fff6;font-size:14px;padding:24px;text-align:center}.lightbox{background:#000000e6}.lightbox-content{align-items:center;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;position:relative}.lightbox-content img{border-radius:8px;max-height:75vh;max-width:100%}.lightbox-close{background:none;border:none;color:#fff;cursor:pointer;font-size:32px;opacity:.7;position:absolute;right:0;top:-40px;transition:opacity .2s}.lightbox-close:hover{opacity:1}.lightbox-caption{color:#fffc;font-size:14px;margin-top:16px;text-align:center}.btn-delete-photo{background:#ef444426;border:1px solid #ef44444d;border-radius:8px;color:#fca5a5;cursor:pointer;font-size:13px;margin-top:16px;padding:10px 20px;transition:all .2s}.btn-delete-photo:hover{background:#ef444440}.btn-delete-story{background:#ef44441a;border:1px solid #ef444433;border-radius:10px;cursor:pointer;flex-shrink:0;font-size:16px;padding:10px 14px;transition:all .2s}.btn-delete-story:hover{background:#ef444433;border-color:#ef444466}.btn-export-pdf{background:#22c55e1a;border:1px solid #22c55e33;border-radius:10px;color:#86efac;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s}.btn-export-pdf:hover{background:#22c55e33;border-color:#22c55e66}.lightbox-caption-section{margin-top:16px;max-width:500px;width:100%}.caption-display{background:#ffffff0d;border-radius:8px;cursor:pointer;padding:12px 16px;transition:background .2s}.caption-display:hover{background:#ffffff1a}.caption-display p{color:#fffc;font-size:14px;margin:0;text-align:center}.caption-placeholder{color:#fff6!important;font-style:italic}.caption-edit{display:flex;flex-direction:column;gap:12px}.caption-edit input{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;font-size:14px;outline:none;padding:12px 16px;text-align:center}.caption-edit input:focus{border-color:#8b5cf6}.caption-actions{display:flex;gap:8px;justify-content:center}.btn-sm{font-size:13px!important;padding:8px 16px!important}.confirm-modal{max-width:400px}.confirm-modal h2{color:#fca5a5}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-danger:hover:not(:disabled){box-shadow:0 10px 20px -5px #ef444466;transform:translateY(-2px)}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.btn-time-capsule{background:#fbbf241a;border:1px solid #fbbf2433;border-radius:10px;cursor:pointer;flex-shrink:0;font-size:16px;padding:10px 14px;transition:all .2s}.btn-time-capsule:hover{background:#fbbf2433;border-color:#fbbf2466}.btn-time-capsule.active{background:#fbbf2433;border-color:#fbbf2480}.time-capsule-banner{align-items:flex-start;border-radius:16px;display:flex;gap:16px;margin-bottom:24px;padding:20px}.time-capsule-banner.locked{background:linear-gradient(135deg,#fbbf241a,#f59e0b0d);border:1px solid #fbbf244d}.time-capsule-banner.unlocked{background:linear-gradient(135deg,#22c55e1a,#16a34a0d);border:1px solid #22c55e4d}.capsule-icon{font-size:32px}.capsule-info strong{color:#fff;display:block;font-size:16px;margin-bottom:4px}.capsule-info p{color:#fff9;font-size:14px;margin:0}.capsule-message{color:#ffffff80!important;font-style:italic;margin-top:8px!important}.time-capsule-modal{max-width:450px}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:12px}.toggle-label input[type=checkbox]{accent-color:#8b5cf6;height:20px;width:20px}.toggle-text{color:#fff;font-size:15px}.time-capsule-modal input[type=date]{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-size:15px;outline:none;padding:14px 18px;width:100%}.time-capsule-modal input[type=date]:focus{border-color:#8b5cf6}.time-capsule-modal textarea{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#fff;font-family:inherit;font-size:15px;outline:none;padding:14px 18px;resize:vertical;width:100%}.time-capsule-modal textarea:focus{border-color:#8b5cf6}.time-capsule-modal textarea::placeholder{color:#ffffff4d}.accept-invite-page{align-items:center;background:linear-gradient(135deg,#0f0f14,#1a1a24);display:flex;justify-content:center;min-height:100vh;padding:20px}.invite-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;max-width:450px;padding:48px;text-align:center;width:100%}.invite-card.error{border-color:#ef444433}.invite-icon{font-size:64px;margin-bottom:24px}.invite-card h2{color:#fff;font-size:28px;font-weight:700;margin:0 0 16px}.invite-message{color:#ffffffb3;font-size:16px;margin:0 0 8px}.family-name{color:#a78bfa;font-size:24px;font-weight:600;margin:0 0 32px}.invite-details{background:#ffffff08;border-radius:12px;margin-bottom:24px;padding:20px}.detail-row{display:flex;justify-content:space-between;padding:8px 0}.detail-row:not(:last-child){border-bottom:1px solid #ffffff0d}.detail-row .label{color:#ffffff80;font-size:14px}.detail-row .value{color:#fff;font-size:14px;font-weight:500;text-transform:capitalize}.login-notice{background:#fbbf240d;border:1px solid #fbbf2426;border-radius:12px;color:#ffffff80;font-size:14px;margin-bottom:24px;padding:16px}.btn-accept{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:14px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px 32px;transition:all .2s;width:100%}.btn-accept:hover:not(:disabled){box-shadow:0 10px 30px -5px #8b5cf666;transform:translateY(-2px)}.btn-accept:disabled{cursor:not-allowed;opacity:.6}.expires-notice{color:#fff6;font-size:12px;margin-top:20px}.spinner-large{animation:spin 1s linear infinite;border:3px solid #ffffff1a;height:40px;margin:0 auto 16px;width:40px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0f0f14,#1a1a24);color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh}.app-loading{align-items:center;display:flex;justify-content:center;min-height:100vh}.spinner-large{animation:spin .8s linear infinite;border:3px solid #8b5cf633;border-radius:50%;border-top-color:#8b5cf6;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-primary:hover:not(:disabled){box-shadow:0 10px 20px -5px #8b5cf666;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#ffffff1a;border:1px solid #ffffff26;border-radius:12px;color:#fffc;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#ffffff26}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}audio{border-radius:8px;height:40px;width:100%}audio::-webkit-media-controls-panel{background:#ffffff1a}
/*# sourceMappingURL=main.ff1fcd6a.css.map*/