@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";.login-page{background:linear-gradient(135deg,#f5e6e8 0%,#e8b4b8 50%,#c44569 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:400px;padding:40px 30px;box-shadow:0 20px 60px #c445694d,inset 0 0 0 1px #ffffff80}.login-header{margin-bottom:32px}.login-logo{margin-bottom:12px;font-size:48px;animation:1.5s ease-in-out infinite heartbeat;display:block}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.login-title{color:#c44569;margin-bottom:8px;font-size:28px;font-weight:700}.login-subtitle{color:#888;font-size:16px}.login-buttons{gap:16px;margin-bottom:24px;display:flex}.login-btn{cursor:pointer;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border:3px solid #0000;border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px 16px;transition:all .3s;display:flex;box-shadow:0 4px 15px #0000001a}.login-btn:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.login-btn.princess:hover,.login-btn.princess.selected{background:linear-gradient(135deg,#ffe4ec 0%,#ffc4d6 100%);border-color:#ff6b9d;box-shadow:0 8px 25px #ff6b9d4d}.login-btn.link:hover,.login-btn.link.selected{background:linear-gradient(135deg,#e0f7fa 0%,#b2ebf2 100%);border-color:#4ecdc4;box-shadow:0 8px 25px #4ecdc44d}.login-emoji{margin-bottom:12px;font-size:48px}.login-name{color:#333;font-size:18px;font-weight:600}.login-hint{color:#999;font-size:14px;font-style:italic}@media (width<=400px){.login-container{padding:30px 20px}.login-title{font-size:24px}.login-emoji{font-size:40px}.login-name{font-size:16px}}.dashboard{padding-top:8px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.logo-section{align-items:center;gap:10px;display:flex}.logo-icon{font-size:28px}.app-title{color:var(--deep-rose);font-size:24px;font-weight:700}.profile-btn{background:var(--blush);cursor:pointer;border:none;border-radius:50%;width:40px;height:40px;font-size:20px;transition:all .2s}.profile-btn:hover{background:var(--rose);transform:scale(1.05)}.welcome-card{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff;border-radius:20px;margin-bottom:20px;padding:24px;box-shadow:0 4px 20px #c445694d}.greeting{margin-bottom:8px;font-size:22px;font-weight:600}.welcome-message{opacity:.95;font-size:14px;line-height:1.5}.welcome-message strong{font-weight:600}.stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{text-align:center;background:#fff;border-radius:16px;padding:16px 12px;transition:all .2s;box-shadow:0 2px 12px #0000000f}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.stat-value{margin-bottom:4px;font-size:28px;font-weight:700}.stat-label{color:var(--warm-gray);font-size:11px;line-height:1.3}.quick-actions{margin-bottom:24px}.section-title{color:var(--charcoal);margin-bottom:12px;font-size:18px;font-weight:600}.action-buttons{flex-direction:column;gap:10px;display:flex}.action-btn{cursor:pointer;text-align:left;border:none;border-radius:14px;align-items:center;gap:12px;padding:16px 20px;font-family:inherit;transition:all .2s;display:flex}.action-btn:active{transform:scale(.98)}.action-primary{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff}.action-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}.action-secondary{color:var(--charcoal);background:#fff;box-shadow:0 2px 12px #0000000f}.action-secondary:hover{background:var(--blush)}.action-tertiary{background:var(--lavender);color:var(--charcoal)}.action-tertiary:hover{background:#d4d4f7}.action-icon{font-size:24px}.action-text{font-size:16px;font-weight:500}.recent-cards{margin-bottom:20px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.view-all-btn{color:var(--deep-rose);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:14px;font-weight:500}.view-all-btn:hover{text-decoration:underline}.recent-cards-list{flex-direction:column;gap:10px;display:flex}.recent-card-item{background:#fff;border-radius:14px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;animation:.4s ease-out backwards slideUp;display:flex;box-shadow:0 2px 10px #0000000d}.recent-card-item:hover{transform:translate(4px);box-shadow:0 4px 14px #00000014}.recent-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.recent-card-info{flex:1;min-width:0}.recent-card-title{color:var(--charcoal);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:15px;font-weight:600;overflow:hidden}.recent-card-meta{color:var(--warm-gray);font-size:12px}.recent-card-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.status-available{background:#e8f5e9}.status-redeemed{background:#f5f5f5}.empty-state{text-align:center;background:#fff;border-radius:20px;padding:40px 20px;box-shadow:0 2px 12px #0000000f}.empty-state p{color:var(--warm-gray);margin-bottom:16px;font-size:14px}.empty-action-btn{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:14px 28px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s}.empty-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}@media (width>=768px){.action-buttons{flex-flow:wrap}.action-btn{flex:1;min-width:150px}.recent-cards-list{grid-template-columns:repeat(2,1fr);display:grid}}.recipient-badge{color:#c44569;background:#fff;border-radius:50px;align-items:center;gap:8px;padding:12px 20px;font-weight:600;display:inline-flex;box-shadow:0 2px 8px #0000001a}.recipient-emoji{font-size:20px;line-height:1}.my-cards{padding-top:8px}.cards-section{margin-bottom:32px}.section-subtitle{color:var(--charcoal);align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.section-icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.available-icon{color:#4caf50;background:#e8f5e9}.redeemed-icon{color:#9e9e9e;background:#f5f5f5}.cards-grid{flex-direction:column;gap:16px;display:flex}.card-item{background:#fff;border-radius:16px;transition:all .2s;overflow:hidden;box-shadow:0 2px 12px #0000000f}.card-item:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001a}.card-item.redeemed{opacity:.85}.card-header{align-items:center;gap:12px;padding:16px 20px;display:flex}.card-icon{font-size:28px}.card-title{color:#fff;text-shadow:0 1px 2px #0000001a;font-size:18px;font-weight:600}.card-body{background:var(--warm-white);padding:16px 20px}.card-message{color:var(--charcoal);border-left:3px solid var(--rose);background:#fff;border-radius:10px;margin-bottom:12px;padding:12px;font-size:14px;font-style:italic;line-height:1.5}.card-meta{color:var(--warm-gray);justify-content:space-between;margin-bottom:16px;font-size:12px;display:flex}.redeem-btn{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s}.redeem-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}.redeem-btn:active{transform:translateY(0)}.redeemed-badge{color:var(--warm-gray);background:#f5f5f5;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;display:flex}.redeemed-badge span:first-child{color:#fff;background:#4caf50;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;display:flex}.empty-section{text-align:center;background:#fff;border-radius:16px;padding:40px 20px;box-shadow:0 2px 12px #0000000f}.empty-icon{margin-bottom:12px;font-size:40px;display:block}.empty-section p{color:var(--charcoal);margin-bottom:4px;font-size:15px;font-weight:500}.empty-hint{color:var(--warm-gray);font-size:13px}@media (width>=768px){.cards-grid{grid-template-columns:repeat(2,1fr);display:grid}}.history{padding-top:8px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title{color:var(--charcoal);font-size:24px;font-weight:700}.header-spacer{width:60px}.history-tabs{gap:8px;margin-bottom:20px;display:flex}.history-tab{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 16px;font-family:inherit;transition:all .2s;display:flex}.history-tab:hover{background:var(--blush)}.history-tab.active{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff;border-color:var(--deep-rose)}.tab-icon{font-size:18px}.tab-text{font-size:14px;font-weight:600}.tab-count{background:#0000001a;border-radius:12px;padding:4px 10px;font-size:12px;font-weight:700}.history-tab.active .tab-count{background:#ffffff4d}.history-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.history-stat{text-align:center;background:#fff;border-radius:14px;padding:16px 12px;box-shadow:0 2px 12px #0000000f}.history-stat-value{color:var(--deep-rose);margin-bottom:4px;font-size:24px;font-weight:700;display:block}.history-stat-label{color:var(--warm-gray);font-size:11px}.history-list{flex-direction:column;gap:12px;display:flex}.history-card{background:#fff;border-radius:16px;align-items:flex-start;gap:14px;padding:16px;transition:all .2s;display:flex;box-shadow:0 2px 12px #0000000f}.history-card:hover{transform:translate(4px);box-shadow:0 4px 16px #0000001a}.history-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.history-card-content{flex:1;min-width:0}.history-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.history-card-title{color:var(--charcoal);font-size:15px;font-weight:600}.history-card-status{border-radius:10px;padding:4px 10px;font-size:11px;font-weight:600}.status-available{color:#4caf50;background:#e8f5e9}.status-redeemed{color:#9e9e9e;background:#f5f5f5}.history-card-message{color:var(--warm-gray);background:var(--warm-white);border-left:3px solid var(--rose);border-radius:10px;margin-bottom:10px;padding:10px;font-size:13px;font-style:italic;line-height:1.4}.history-card-meta{color:var(--warm-gray);justify-content:space-between;font-size:12px;display:flex}.history-card-partner{font-weight:500}.history-card-redeemed{border-top:1px solid var(--light-gray);color:#4caf50;margin-top:10px;padding-top:10px;font-size:12px;font-weight:500}.history-empty{text-align:center;background:#fff;border-radius:20px;padding:60px 20px;box-shadow:0 2px 12px #0000000f}.history-empty-icon{margin-bottom:16px;font-size:56px;display:block}.history-empty p{color:var(--warm-gray);font-size:15px}@media (width>=768px){.history-list{grid-template-columns:repeat(2,1fr);display:grid}}.create-card{background:var(--cream);min-height:100vh}.create-card-header{border-bottom:1px solid var(--light-gray);background:#fff;align-items:center;gap:16px;padding:20px 16px;display:flex}.back-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:8px;font-size:24px;transition:background .2s}.back-btn:hover{background:var(--blush)}.create-card-title{color:var(--charcoal);font-size:20px;font-weight:700}.create-card-form{max-width:480px;margin:0 auto;padding:24px 16px}.form-group{margin-bottom:24px}.form-label{color:var(--charcoal);margin-bottom:8px;font-size:14px;font-weight:600;display:block}.form-input,.form-textarea{border:2px solid var(--light-gray);width:100%;font-size:16px;font-family:var(--font-family);background:#fff;border-radius:12px;padding:14px 18px;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--rose);outline:none}.form-textarea{resize:vertical;min-height:100px}.icon-selector{flex-wrap:wrap;gap:12px;display:flex}.icon-option{border:2px solid var(--light-gray);cursor:pointer;background:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;transition:all .2s;display:flex}.icon-option:hover{border-color:var(--rose);transform:scale(1.05)}.icon-option.selected{border-color:var(--deep-rose);background:var(--blush);box-shadow:0 2px 8px #c4456933}.color-selector{flex-wrap:wrap;gap:12px;display:flex}.color-option{cursor:pointer;border:3px solid #0000;border-radius:50%;width:48px;height:48px;transition:all .2s;box-shadow:0 2px 8px #0000001a}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--charcoal);transform:scale(1.1)}.create-btn{color:#fff;background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:8px;padding:16px;font-size:18px;font-weight:600;transition:all .2s}.create-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}.create-btn:disabled{background:var(--light-gray);cursor:not-allowed;box-shadow:none;transform:none}.success-message{text-align:center;padding:40px 24px}.success-icon{margin-bottom:16px;font-size:64px}.success-title{color:var(--deep-rose);margin-bottom:8px;font-size:24px;font-weight:700}.success-text{color:var(--warm-gray);margin-bottom:24px;font-size:16px}.success-btn{color:#fff;background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);cursor:pointer;border:none;border-radius:12px;padding:14px 32px;font-size:16px;font-weight:600;transition:all .2s}.success-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}.navigation{border-top:1px solid var(--light-gray);z-index:100;background:#fff;justify-content:space-around;padding:12px 0 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000d}.nav-item{color:var(--warm-gray);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;font-size:12px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--deep-rose);background:var(--blush)}.nav-item.active{color:var(--deep-rose)}.nav-icon{font-size:24px;line-height:1}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:360px;padding:32px 24px;animation:.3s ease-out slideUp;box-shadow:0 20px 60px #0003}.modal-title{color:var(--deep-rose);margin-bottom:20px;font-size:24px;font-weight:700}.modal-card-preview{background:linear-gradient(135deg, var(--rose) 0%, var(--blush) 100%);text-align:left;border-radius:16px;margin-bottom:20px;padding:20px}.modal-card-icon{margin-bottom:8px;font-size:40px}.modal-card-title{color:#fff;margin-bottom:4px;font-size:18px;font-weight:600}.modal-card-from{color:#ffffffe6;font-size:14px}.modal-message{color:var(--warm-gray);margin-bottom:24px;font-size:16px;line-height:1.5}.modal-actions{gap:12px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:14px 20px;font-size:16px;font-weight:600;transition:all .2s}.modal-btn-cancel{background:var(--light-gray);color:var(--charcoal)}.modal-btn-cancel:hover{background:#d0d0d0}.modal-btn-confirm{background:linear-gradient(135deg, var(--deep-rose) 0%, var(--rose) 100%);color:#fff}.modal-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 4px 15px #c4456966}.profile-container{position:relative}.profile-button{cursor:pointer;background:#fff;border:2px solid #e8b4b8;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.profile-button:hover{border-color:#c44569;transform:scale(1.05);box-shadow:0 4px 12px #00000026}.profile-emoji{font-size:24px;line-height:1}.profile-dropdown{z-index:1000;background:#fff;border:1px solid #e8b4b84d;border-radius:16px;min-width:180px;padding:16px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 32px #00000026}.profile-header{align-items:center;gap:12px;padding-bottom:12px;display:flex}.profile-emoji-large{font-size:32px;line-height:1}.profile-name{color:#333;font-size:16px;font-weight:600}.profile-divider{background:linear-gradient(90deg,#0000,#e8b4b8,#0000);height:1px;margin:8px 0}.profile-logout-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:12px;align-items:center;gap:10px;width:100%;padding:12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.profile-logout-btn:hover{color:#c44569;background:#f5e6e8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app{background-color:var(--cream);min-height:100vh;position:relative}.app-header{z-index:100;padding:16px;position:fixed;top:0;right:0}.main-content{padding-top:8px;padding-bottom:100px}.error-banner{color:#fff;text-align:center;z-index:200;cursor:pointer;background:#ff6b6b;padding:12px 16px;font-weight:600;animation:.3s ease-out slideDown;position:fixed;top:0;left:0;right:0}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.loading-overlay{z-index:150;background:#fffc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-spinner{border:4px solid #e8b4b8;border-top-color:#c44569;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}:root{--rose:#e8b4b8;--blush:#f5e6e8;--deep-rose:#c44569;--warm-coral:#ff6b6b;--soft-peach:#ffd4c4;--lavender:#e6e6fa;--cream:#fff8f0;--warm-white:snow;--charcoal:#2d2d2d;--warm-gray:#6b6b6b;--light-gray:#e8e8e8;--soft-shadow:#00000014;--available:#4caf50;--redeemed:#9e9e9e;--pending:#ff9800;--font-family:"Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--cream);color:var(--charcoal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh}@keyframes celebrate{0%{opacity:0;transform:scale(0)rotate(0)}50%{opacity:1;transform:scale(1.2)rotate(180deg)}to{opacity:1;transform:scale(1)rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-10px)rotate(5deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.animate-celebrate{animation:.6s cubic-bezier(.68,-.55,.265,1.55) celebrate}.animate-float{animation:2s ease-in-out infinite float}.animate-slide-up{animation:.4s ease-out slideUp}.animate-fade-in{animation:.3s ease-out fadeIn}.animate-pulse{animation:2s ease-in-out infinite pulse}.container{max-width:100%;padding:16px 16px 100px}@media (width>=768px){.container{max-width:720px;margin:0 auto;padding:24px 24px 100px}}@media (width>=1024px){.container{max-width:960px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--blush)}::-webkit-scrollbar-thumb{background:var(--rose);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--deep-rose)}
