:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: rgba(255, 255, 255, .04);--bg-glass: rgba(255, 255, 255, .06);--bg-glass-hover: rgba(255, 255, 255, .1);--bg-input: rgba(255, 255, 255, .08);--accent-primary: #e8756a;--accent-secondary: #c44fe2;--accent-tertiary: #f0a35e;--accent-gradient: linear-gradient(135deg, #e8756a 0%, #c44fe2 50%, #6c5ce7 100%);--accent-gradient-warm: linear-gradient(135deg, #e8756a 0%, #f0a35e 50%, #f7c948 100%);--text-primary: #f0f0f5;--text-secondary: rgba(240, 240, 245, .65);--text-muted: rgba(240, 240, 245, .4);--text-accent: #e8756a;--border-subtle: rgba(255, 255, 255, .08);--border-accent: rgba(232, 117, 106, .3);--success: #4ade80;--warning: #fbbf24;--error: #f87171;--info: #60a5fa;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Playfair Display", Georgia, serif;--font-script: "Dancing Script", cursive;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--text-5xl: 3.5rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50%;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(232, 117, 106, .15);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(232,117,106,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(196,79,226,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(108,92,231,.05) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-tertiary)}.glass-card{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base)}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px #e8756a4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px #e8756a66}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-glass)}.btn-danger{background:#f8717126;color:var(--error);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:#f8717140}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-group label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.input{padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e8756a26;background:#ffffff1a}.input::placeholder{color:var(--text-muted)}textarea.input{min-height:100px;resize:vertical}select.input{cursor:pointer;color-scheme:dark;background-color:var(--bg-input);color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(240,240,245,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}select.input option{background:#1a1a24;color:var(--text-primary)}.page-container{max-width:1200px;margin:0 auto;padding:var(--space-lg) var(--space-lg) var(--space-3xl)}.page-header{margin-bottom:var(--space-xl)}.page-header h1{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{color:var(--text-secondary);margin-top:var(--space-xs)}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-draft{background:#60a5fa26;color:var(--info)}.badge-scheduled{background:#fbbf2426;color:var(--warning)}.badge-sent{background:#4ade8026;color:var(--success)}.badge-viewed{background:#c44fe226;color:var(--accent-secondary)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-3xl)}.spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-secondary)}.empty-state svg{width:64px;height:64px;opacity:.3;margin-bottom:var(--space-md)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .2s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:var(--space-xl);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.modal-header h2{font-family:var(--font-display);font-size:var(--text-xl)}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{color:var(--text-primary);background:var(--bg-glass)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.toast{position:fixed;bottom:var(--space-lg);right:var(--space-lg);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;z-index:2000;animation:slideUp .3s ease,fadeOut .3s ease 3s forwards;max-width:400px}.toast-success{background:#4ade8026;border:1px solid rgba(74,222,128,.3);color:var(--success)}.toast-error{background:#f8717126;border:1px solid rgba(248,113,113,.3);color:var(--error)}@keyframes fadeOut{to{opacity:0;transform:translateY(10px)}}@media(max-width:768px){:root{--text-3xl: 1.75rem;--text-4xl: 2rem;--text-5xl: 2.5rem}.page-container{padding:var(--space-md) var(--space-md) var(--space-2xl)}}.navbar{position:sticky;top:0;z-index:100;background:#0a0a0fcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);padding:0 var(--space-lg)}.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}.navbar-brand{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none;font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.navbar-brand svg{color:var(--accent-primary)}.navbar-brand span{background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links{display:flex;align-items:center;gap:var(--space-xs)}.nav-link{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--text-primary);background:var(--bg-glass)}.nav-link.active{color:var(--accent-primary)}.nav-link svg{width:18px;height:18px}.navbar-actions{display:flex;align-items:center;gap:var(--space-sm)}.nav-user{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);color:var(--text-secondary);font-size:var(--text-sm)}.nav-user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:#fff}@media(max-width:768px){.nav-link span{display:none}.nav-user span:not(.nav-user-avatar){display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.auth-card{width:100%;max-width:440px;padding:var(--space-2xl);animation:slideUp .5s cubic-bezier(.4,0,.2,1)}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-logo{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.auth-logo svg{color:var(--accent-primary)}.auth-logo h1{font-family:var(--font-display);font-size:var(--text-3xl);background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-secondary);font-size:var(--text-sm)}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-form .btn-primary{margin-top:var(--space-sm);padding:var(--space-md);font-size:var(--text-base)}.auth-error{padding:var(--space-sm) var(--space-md);background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-md);color:var(--error);font-size:var(--text-sm);text-align:center}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer a{color:var(--accent-primary);font-weight:600}.dashboard{animation:fadeIn .4s ease}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-sm)}.stat-card .stat-value{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-display)}.stat-card .stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.dashboard-section{padding:var(--space-lg)}.dashboard-section h2{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.dashboard-section h2 svg{color:var(--accent-primary)}.upcoming-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-card);margin-bottom:var(--space-sm);transition:all var(--transition-fast)}.upcoming-item:hover{background:var(--bg-glass-hover)}.upcoming-date{min-width:48px;text-align:center}.upcoming-date .day{font-size:var(--text-2xl);font-weight:800;font-family:var(--font-display);color:var(--accent-primary);line-height:1}.upcoming-date .month{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.upcoming-info h4{font-size:var(--text-sm);font-weight:600}.upcoming-info p{font-size:var(--text-xs);color:var(--text-secondary)}.recent-card-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-card);margin-bottom:var(--space-sm)}.recent-card-info h4{font-size:var(--text-sm);font-weight:600}.recent-card-info p{font-size:var(--text-xs);color:var(--text-secondary)}.quick-action{margin-top:var(--space-lg);text-align:center}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.contacts-page .contacts-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-md);flex-wrap:wrap}.contacts-search{flex:1;max-width:360px}.contacts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-md)}.contact-card{padding:var(--space-lg);cursor:pointer;position:relative;overflow:hidden}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-fast)}.contact-card:hover:before{opacity:1}.contact-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.contact-avatar{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-lg);color:#fff;flex-shrink:0}.contact-name h3{font-size:var(--text-base);font-weight:600}.contact-name p{font-size:var(--text-xs);color:var(--text-secondary)}.contact-details{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--text-sm);color:var(--text-secondary)}.contact-details span{display:flex;align-items:center;gap:var(--space-xs)}.contact-details svg{width:14px;height:14px;color:var(--text-muted)}.contact-occasions-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.occasion-tag{padding:2px var(--space-sm);border-radius:var(--radius-sm);font-size:11px;background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-secondary)}.contact-actions{display:flex;gap:var(--space-xs);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-subtle)}.contact-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.occasions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xs)}.occasion-checkbox{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;font-size:var(--text-xs);transition:all var(--transition-fast);border:1px solid transparent}.occasion-checkbox:hover{background:var(--bg-glass-hover)}.occasion-checkbox.selected{background:#e8756a1a;border-color:var(--accent-primary);color:var(--accent-primary)}.occasion-checkbox input{display:none}.contact-images-section{margin-top:var(--space-sm)}.contact-images-section h4{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-sm)}.images-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-xs)}.image-slot{aspect-ratio:1;border-radius:var(--radius-sm);border:2px dashed var(--border-subtle);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);overflow:hidden;position:relative}.image-slot:hover{border-color:var(--accent-primary);background:#e8756a0d}.image-slot img{width:100%;height:100%;object-fit:cover}.image-slot .remove-img{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:var(--radius-full);background:#000000b3;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px;opacity:0;transition:opacity var(--transition-fast)}.image-slot:hover .remove-img{opacity:1}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-md)}@media(max-width:768px){.form-row{grid-template-columns:1fr}.occasions-grid{grid-template-columns:repeat(2,1fr)}.images-grid{grid-template-columns:repeat(4,1fr)}}.add-photo-slot{flex-direction:column;gap:4px}.add-photo-label{font-size:10px;color:var(--text-muted)}.contact-card-history{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-subtle)}.contact-card-history h3{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-md);color:var(--text-primary)}.contact-cards-list{display:flex;flex-direction:column;gap:var(--space-xs)}.contact-card-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.contact-card-icon{font-size:var(--text-lg);flex-shrink:0}.contact-card-info{flex:1;display:flex;flex-direction:column}.contact-card-info strong{font-size:var(--text-sm);font-weight:600}.contact-card-date{font-size:var(--text-xs);color:var(--text-muted)}.calendar-page .calendar-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.calendar-nav h2{font-family:var(--font-display);font-size:var(--text-2xl);min-width:220px;text-align:center}.calendar-nav button{background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-primary);width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.calendar-nav button:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary)}.calendar-grid-container{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-lg);overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-sm)}.calendar-weekday{text-align:center;font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:var(--space-sm)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{min-height:80px;padding:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-card);transition:all var(--transition-fast);cursor:pointer;position:relative}.calendar-day:hover{background:var(--bg-glass-hover)}.calendar-day.other-month{opacity:.3}.calendar-day.today{border:1px solid var(--accent-primary);background:#e8756a0d}.calendar-day .day-number{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-xs)}.calendar-day.today .day-number{color:var(--accent-primary)}.calendar-event{font-size:10px;padding:1px 4px;border-radius:3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event.birthday{background:#e8756a33;color:var(--accent-primary)}.calendar-event.holiday{background:#4ade8033;color:var(--success)}.calendar-event.card-scheduled{background:#fbbf2433;color:var(--warning)}.calendar-legend{display:flex;gap:var(--space-lg);justify-content:center;margin-top:var(--space-lg)}.legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-xs);color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:var(--radius-full)}@media(max-width:768px){.calendar-day{min-height:50px;padding:4px}.calendar-day .day-number{font-size:var(--text-xs)}.calendar-event{font-size:8px}}.calendar-day.has-events{cursor:pointer}.calendar-day.has-events:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.day-detail-modal{width:420px;max-width:90vw;max-height:80vh;overflow-y:auto;animation:fadeIn .2s ease}.day-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.day-detail-modal .modal-header h2{font-family:var(--font-display);font-size:var(--text-xl)}.day-section{margin-bottom:var(--space-lg)}.day-section h3{font-size:var(--text-md);margin-bottom:var(--space-sm);color:var(--text-secondary)}.day-contacts-list{display:flex;flex-direction:column;gap:var(--space-sm)}.day-contact-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.day-contact-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:var(--text-sm);flex-shrink:0}.day-contact-info{flex:1;min-width:0}.day-contact-info strong{display:block;font-size:var(--text-sm)}.day-contact-rel{font-size:var(--text-xs);color:var(--text-muted)}.day-event-row{padding:var(--space-sm) var(--space-md);background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-subtle);font-size:var(--text-sm);margin-bottom:var(--space-xs)}.card-creator{animation:fadeIn .4s ease}.wizard-steps{display:flex;justify-content:center;gap:var(--space-xs);margin-bottom:var(--space-xl);flex-wrap:wrap}.wizard-step{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-xl);font-size:var(--text-xs);font-weight:600;color:var(--text-muted);background:var(--bg-card);transition:all var(--transition-base)}.wizard-step.active{background:var(--accent-gradient);color:#fff}.wizard-step.completed{background:#4ade8026;color:var(--success)}.wizard-step.completed:hover{background:#4ade8040;transform:translateY(-1px)}.wizard-step-num{width:22px;height:22px;border-radius:var(--radius-full);background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:11px}.step-content{max-width:800px;margin:0 auto}.step-content h2{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-sm);text-align:center}.step-content>p{text-align:center;color:var(--text-secondary);margin-bottom:var(--space-lg)}.recipient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md)}.recipient-item{padding:var(--space-lg);text-align:center;cursor:pointer;border:2px solid transparent;transition:all var(--transition-base)}.recipient-item:hover{transform:translateY(-2px)}.recipient-item.selected{border-color:var(--accent-primary);background:#e8756a14}.recipient-avatar{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:700;color:#fff;margin:0 auto var(--space-sm)}.recipient-item h4{font-size:var(--text-sm);margin-bottom:2px}.recipient-item p{font-size:var(--text-xs);color:var(--text-secondary)}.occasion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-md)}.occasion-item{padding:var(--space-lg);text-align:center;cursor:pointer;border:2px solid transparent;transition:all var(--transition-base)}.occasion-item:hover{transform:translateY(-2px)}.occasion-item.selected{border-color:var(--accent-primary);background:#e8756a14}.occasion-icon{font-size:var(--text-3xl);margin-bottom:var(--space-sm)}.occasion-item h4{font-size:var(--text-sm)}.greeting-list{display:flex;flex-direction:column;gap:var(--space-sm)}.greeting-item{padding:var(--space-md) var(--space-lg);cursor:pointer;border:2px solid transparent;font-size:var(--text-sm);line-height:1.5;transition:all var(--transition-base)}.greeting-item:hover{transform:translate(4px)}.greeting-item.selected{border-color:var(--accent-primary);background:#e8756a14}.greeting-toggle{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.greeting-toggle .btn{display:flex;align-items:center;gap:var(--space-xs)}.custom-greeting-section{animation:fadeIn .3s ease}.card-text-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);max-width:600px;margin:0 auto var(--space-xl)}@media(max-width:600px){.card-text-fields{grid-template-columns:1fr}}.signoff-options{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-sm)}.signoff-chip{padding:6px 12px;border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-subtle);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:4px}.signoff-chip:hover{border-color:var(--accent-primary);background:#e8756a14}.signoff-chip.selected{border-color:var(--accent-primary);background:#e8756a26;color:var(--accent-primary);font-weight:600}.signoff-preview{margin-top:var(--space-sm);font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-sm) var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md)}.template-item{cursor:pointer;border:2px solid transparent;border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.template-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.template-item.selected{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.template-preview{height:200px;position:relative;overflow:hidden}.template-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.template-text{color:#fff;font-size:var(--text-lg);font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.5);text-align:center}.template-name{padding:var(--space-xs) var(--space-sm);background:var(--bg-card);font-size:var(--text-xs);font-weight:600;text-align:center;color:var(--text-secondary)}.front-text-editor{animation:fadeIn .3s ease}.style-item{cursor:pointer;border:2px solid transparent;border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.style-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.style-item.selected{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.style-preview{height:140px;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:600;padding:var(--space-md);text-align:center}.style-info{padding:var(--space-sm) var(--space-md);background:var(--bg-card)}.style-info h4{font-size:var(--text-sm);font-weight:600}.style-info p{font-size:var(--text-xs);color:var(--text-secondary)}.card-preview-container{perspective:1200px;display:flex;justify-content:center;padding:var(--space-xl) 0}.card-3d{width:360px;height:480px;position:relative;cursor:pointer;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.4,0,.2,1)}.card-3d.flipped{transform:rotateY(-180deg)}.card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center}.card-front .card-occasion-icon{font-size:64px;margin-bottom:var(--space-lg)}.card-front .card-title{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-sm)}.card-front .card-to{font-size:var(--text-sm);opacity:.8}.card-back{transform:rotateY(180deg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg)}.card-back .card-greeting{font-size:var(--text-lg);line-height:1.6;max-width:280px}.card-back .card-message{font-size:var(--text-sm);opacity:.7;font-style:italic;max-width:280px}.card-back .card-from{font-size:var(--text-sm);opacity:.8;margin-top:var(--space-md)}.flip-hint{text-align:center;font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-sm)}.schedule-section{max-width:400px;margin:0 auto;text-align:center}.schedule-section .input-group{text-align:left;margin-bottom:var(--space-lg)}.wizard-nav{display:flex;justify-content:center;gap:var(--space-md);margin-top:var(--space-xl)}.success-state{text-align:center;padding:var(--space-3xl);animation:slideUp .5s ease}.success-state .success-icon{font-size:80px;margin-bottom:var(--space-lg)}.success-state h2{font-family:var(--font-display);font-size:var(--text-3xl);background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.success-state p{color:var(--text-secondary);margin-bottom:var(--space-lg)}.public-link{padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);font-family:monospace;font-size:var(--text-sm);word-break:break-all;color:var(--accent-primary);margin-bottom:var(--space-lg);border:1px solid var(--border-subtle)}@media(max-width:768px){.card-3d{width:280px;height:380px}.recipient-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.occasion-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.sent-cards-page .sent-filters{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg)}.sent-filter{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:500;background:var(--bg-card);border:1px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.sent-filter:hover{background:var(--bg-glass-hover)}.sent-filter.active{background:#e8756a1a;border-color:var(--accent-primary);color:var(--accent-primary)}.sent-cards-list{display:flex;flex-direction:column;gap:var(--space-md)}.sent-card-row{padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-lg)}.sent-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);flex-shrink:0}.sent-card-details{flex:1}.sent-card-details h3{font-size:var(--text-base);font-weight:600;margin-bottom:2px}.sent-card-details p{font-size:var(--text-sm);color:var(--text-secondary)}.sent-card-email{display:flex;align-items:center;gap:4px;font-size:var(--text-xs)!important;color:var(--text-muted)!important;margin-top:2px}.sent-card-meta{text-align:right;flex-shrink:0}.sent-card-meta .date{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:4px}.sent-card-actions{display:flex;gap:var(--space-xs);margin-left:var(--space-md)}@media(max-width:768px){.sent-card-row{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.sent-card-meta{text-align:left}.sent-card-actions{margin-left:0}}.public-viewer{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--bg-primary);position:relative;overflow:hidden}.public-viewer:before{content:"";position:absolute;inset:-50%;background:radial-gradient(ellipse at 30% 30%,rgba(232,117,106,.1) 0%,transparent 50%),radial-gradient(ellipse at 70% 70%,rgba(196,79,226,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(108,92,231,.06) 0%,transparent 50%);animation:bgFloat 20s ease-in-out infinite;pointer-events:none}@keyframes bgFloat{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(2%,-2%) rotate(1deg)}50%{transform:translate(-1%,3%) rotate(-1deg)}75%{transform:translate(3%,1%) rotate(.5deg)}}.envelope-container{position:relative;z-index:1;animation:floatIn 1s cubic-bezier(.4,0,.2,1)}@keyframes floatIn{0%{opacity:0;transform:translateY(40px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.envelope-intro{text-align:center;margin-bottom:var(--space-xl)}.envelope-intro h1{font-family:var(--font-display);font-size:var(--text-4xl);background:var(--accent-gradient-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.envelope-intro p{color:var(--text-secondary);font-size:var(--text-lg)}.envelope-intro .from-line{margin-top:var(--space-sm);font-size:var(--text-sm);color:var(--text-muted)}.open-card-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-2xl);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-xl);font-size:var(--text-lg);font-weight:600;font-family:var(--font-body);cursor:pointer;margin:var(--space-lg) auto;animation:pulse 2s ease-in-out infinite;box-shadow:0 4px 30px #e8756a66;transition:all var(--transition-base)}.open-card-btn:hover{transform:scale(1.05);box-shadow:0 6px 40px #e8756a80}@keyframes pulse{0%,to{box-shadow:0 4px 30px #e8756a66}50%{box-shadow:0 4px 50px #e8756a99}}.public-card-display{perspective:1200px;margin:var(--space-xl) 0}.public-card{width:400px;height:540px;position:relative;transform-style:preserve-3d;transition:transform 1.2s cubic-bezier(.4,0,.2,1);cursor:pointer}.public-card.showing-inside{transform:rotateY(-180deg)}.public-card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 20px 60px #0006,0 0 40px #e8756a1a;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center}.public-card-front .front-icon{font-size:80px;margin-bottom:var(--space-xl);animation:bounceIn .6s ease .5s both}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.public-card-front .front-title{font-size:var(--text-3xl);font-weight:700;margin-bottom:var(--space-md);line-height:1.2}.public-card-front .front-to{font-size:var(--text-lg);opacity:.8}.public-card-inside{transform:rotateY(180deg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xl)}.public-card-inside .inside-greeting{font-size:var(--text-xl);line-height:1.7;max-width:320px}.public-card-inside .inside-message{font-size:var(--text-base);opacity:.7;font-style:italic;max-width:300px;line-height:1.6}.public-card-inside .inside-from{font-size:var(--text-base);opacity:.8;margin-top:var(--space-md)}.flip-instruction{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-md);animation:fadeIn .5s ease 1.5s both}.public-footer{margin-top:var(--space-2xl);text-align:center;color:var(--text-muted);font-size:var(--text-xs);position:relative;z-index:1}.public-footer a{color:var(--accent-primary)}.card-not-found{text-align:center;position:relative;z-index:1}.card-not-found h1{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--text-primary);margin-bottom:var(--space-md)}.card-not-found p{color:var(--text-secondary);font-size:var(--text-lg)}@media(max-width:768px){.public-card{width:300px;height:420px}.envelope-intro h1{font-size:var(--text-3xl)}.public-card-front .front-icon{font-size:60px}.public-card-front .front-title{font-size:var(--text-2xl)}}
