*,*:before,*:after{box-sizing:border-box}html{padding:0!important;margin:0!important}body{margin:0;padding:0!important;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;color:#0a0a0a;background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}h1,h2,h3,h4,p{margin:0}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{text-decoration:none;color:inherit}.navbar{position:fixed;top:0;left:0;right:0;z-index:50;background:#9c528b;height:60px;display:flex;align-items:center;padding:0 32px;justify-content:space-between;box-shadow:0 1px 3px #0003}.navbar-brand{color:#fff;font-size:20px;font-weight:600;letter-spacing:-.3px;text-decoration:none}.navbar-links{display:flex;align-items:center;gap:24px}.navbar-link{font-size:14px;font-weight:500;color:#d1dadb;text-decoration:none;transition:color .15s}.navbar-link:hover{color:#fff}.navbar-link.active{color:#fff;text-decoration:underline;text-underline-offset:4px}.navbar-avatar{width:32px;height:32px;border-radius:50%;background:#333;display:flex;align-items:center;justify-content:center;border:2px solid #555}.navbar-avatar span{color:#fff;font-size:11px;font-weight:600}.navbar-logout{font-size:14px;font-weight:500;color:#d1dadb;background:none;border:none;cursor:pointer;transition:color .15s;padding:0}.navbar-logout:hover{color:#fff}.navbar-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.signup-page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:100px 40px 60px;background:#fff}.signup-inner{display:flex;flex-direction:row;align-items:center;gap:48px;max-width:1200px;width:100%}.signup-content{display:flex;flex-direction:column;align-items:flex-start;gap:60px;flex:1}.signup-text{display:flex;flex-direction:column;align-items:flex-start;gap:16px}.signup-title{color:#111;font-size:48px;font-weight:600;line-height:1.3}.signup-subtitle{color:#666c;font-size:28px;font-weight:350;line-height:1.4;width:80%}.signup-button{display:flex;height:56px;padding:0 32px;justify-content:center;align-items:center;border-radius:40px;border:1px solid #333;background:#fff;gap:8px;font-size:16px;width:80%;cursor:pointer;transition:background .15s,color .15s}.signup-button:hover{background:#f5f5f5}.google-icon{width:20px;height:20px}.signup-image-wrap{flex-shrink:0;width:500px}.signup-image{width:100%;height:auto;border-radius:16px}@media(max-width:1000px){.signup-inner{flex-direction:column;gap:40px}.signup-image-wrap{width:100%}.signup-title{font-size:36px}.signup-subtitle{font-size:20px;width:100%}.signup-button{width:100%}}@media(max-width:480px){.signup-page{padding:40px 20px}.signup-title{font-size:28px}.signup-subtitle{font-size:18px}}.dashboard-page{min-height:100vh;background:#fbeff4;padding-top:60px}.dashboard-inner{max-width:1200px;margin:0 auto;padding:40px 32px}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}.dashboard-title{font-size:30px;font-weight:500;color:#0a0a0a;letter-spacing:-.3px}.dashboard-subtitle{font-size:16px;color:#717182;margin-top:4px}.dashboard-empty{text-align:center;padding:80px 0;color:#717182}.dashboard-empty p:first-child{font-size:18px;margin-bottom:8px}.dashboard-empty p:last-child{font-size:14px}.event-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media(max-width:900px){.event-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.event-grid{grid-template-columns:1fr}}.event-card{background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 12px #0000000f;overflow:hidden;cursor:pointer;transition:box-shadow .2s}.event-card:hover{box-shadow:0 4px 20px #0000001f}.event-card-image{position:relative;height:110px;overflow:hidden}.event-card-image img{width:100%;height:100%;object-fit:cover}.event-card-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.5),transparent)}.event-type-badge{position:absolute;top:12px;right:12px;color:#fff;font-size:11px;font-weight:500;padding:2px 8px;border-radius:8px}.event-card-body{padding:20px;display:flex;flex-direction:column;gap:12px}.event-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.event-card-title-wrap{flex:1;min-width:0}.event-card-name{font-size:16px;font-weight:500;color:#0a0a0a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-card-date{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:13px;color:#717182}.event-card-stats{border-top:1px solid #f3f4f6;padding-top:12px;display:flex;flex-direction:column;gap:10px}.event-stat-row{display:flex;align-items:center;justify-content:space-between}.event-stat-label{display:flex;align-items:center;gap:6px;font-size:13px;color:#717182}.event-stat-value{font-size:13px;font-weight:500}.budget-spent{color:#00a63e}.budget-spent.warning{color:#f59e0b}.budget-spent.over{color:#ef4444}.budget-total{color:#717182;font-weight:400}.contact-chips{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.contact-chip{display:flex;align-items:center;gap:6px;background:#ececf0;border-radius:999px;padding:2px 8px}.contact-chip-avatar{width:20px;height:20px;border-radius:50%;background:#d4d4d8;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:500;color:#0a0a0a}.contact-chip-name{font-size:12px;color:#0a0a0a}.contact-chip-more{background:#eceef2;color:#030213;font-size:11px;font-weight:500;padding:2px 8px;border-radius:8px}.circular-progress{position:relative;flex-shrink:0}.circular-progress svg{transform:rotate(-90deg);position:absolute;top:0;right:0;bottom:0;left:0}.circular-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#0a0a0a}.modal-box{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;width:100%;max-width:512px;max-height:90vh;overflow-y:auto}.modal-body{padding:24px;display:flex;flex-direction:column;gap:20px}.recipient-picker{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:12px;display:flex;flex-wrap:wrap;gap:8px;min-height:44px}.recipient-btn{padding:4px 12px;border-radius:999px;font-size:12px;font-weight:500;border:1px solid #e5e7eb;background:#fff;color:#717182;transition:all .15s}.recipient-btn:hover{border-color:#9ca3af}.recipient-btn.selected{background:#0a0a0a;color:#fff;border-color:#0a0a0a}.dashboard-section{margin-bottom:40px}.dashboard-section-heading{font-size:18px;font-weight:600;color:#0a0a0a;margin-bottom:16px}.btn-create-type{display:inline-flex;align-items:center;gap:5px;margin-top:6px;padding:0;border:none;background:transparent;font-size:12px;color:#6366f1;cursor:pointer;font-weight:500}.btn-create-type:hover{text-decoration:underline}.custom-type-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:8px}.custom-type-row .form-input{flex:1;min-width:160px}.form-input{width:50px}.color-picker{width:36px;height:36px;border:none;border-radius:8px;padding:2px;cursor:pointer;background:#f3f3f5;flex-shrink:0}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:6px}.form-label-optional{font-size:12px;font-weight:400;color:#9ca3af}.contacts-page{min-height:100vh;background:#fbeff4;padding-top:60px}.contacts-inner{max-width:1200px;margin:0 auto;padding:40px 32px}.contacts-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}.contacts-title{font-size:30px;font-weight:500;color:#0a0a0a;letter-spacing:-.3px}.contacts-subtitle{font-size:16px;color:#717182;margin-top:4px}.contacts-empty{text-align:center;padding:80px 0;color:#717182}.contacts-empty p:first-child{font-size:18px;margin-bottom:8px}.contacts-empty p:last-child{font-size:14px}.contacts-list{background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 12px #0000000d;overflow:hidden}.contact-row{display:flex;align-items:center;gap:16px;padding:16px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(0,0,0,.06)}.contact-row:last-child{border-bottom:none}.contact-row:hover{background:#fafafa}.contact-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#ececf0;display:flex;align-items:center;justify-content:center}.contact-avatar img{width:100%;height:100%;object-fit:cover}.contact-avatar span{font-size:14px;font-weight:500;color:#717182}.contact-name-col{width:160px;flex-shrink:0}.contact-name{font-size:15px;font-weight:500;color:#0a0a0a}.contact-relationship{font-size:13px;color:#717182}.contact-event-col{flex:1;min-width:0}.contact-event-name-row{display:flex;align-items:center;gap:6px}.contact-event-name{font-size:13px;font-weight:500;color:#0a0a0a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-event-date{font-size:12px;color:#717182;margin-top:2px;padding-left:20px}.contact-event-more{font-size:12px;color:#717182;padding-left:20px}.contact-no-events{font-size:13px;color:#b0b0b8}.contact-badge-col{width:110px;flex-shrink:0;display:flex;justify-content:center}.event-badge{display:inline-block;padding:2px 10px;border-radius:8px;font-size:12px;font-weight:500;color:#fff;border:none}.contact-budget-col{width:130px;flex-shrink:0}.contact-budget-row{display:flex;align-items:center;gap:4px;color:#717182}.contact-budget-amount{font-size:15px;font-weight:500;color:#0a0a0a}.contact-budget-label{font-size:12px;color:#717182;padding-left:18px}.contact-gifts-col{width:90px;flex-shrink:0}.contact-gifts-row{display:flex;align-items:center;gap:4px;color:#717182}.contact-gifts-count{font-size:15px;font-weight:500;color:#0a0a0a}.contact-gifts-label{font-size:12px;color:#717182;padding-left:18px}.modal-box{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;width:100%;max-width:448px}.btn-add{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;border:1px solid #0a0a0a;font-size:14px;font-weight:500;color:#0a0a0a;background:transparent;transition:background .15s,color .15s;white-space:nowrap}.btn-add:hover{background:#0a0a0a;color:#fff}.detail-page{min-height:100vh;background:#fafafa;padding-top:60px}.detail-inner{max-width:860px;margin:0 auto;padding:32px 24px}.detail-back{display:flex;align-items:center;gap:6px;font-size:14px;color:#717182;background:none;border:none;padding:0;margin-bottom:24px;transition:color .15s}.detail-back:hover{color:#0a0a0a}.detail-card{background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 12px #0000000d;padding:24px;margin-bottom:20px}.detail-contact-header{display:flex;align-items:flex-start;justify-content:space-between}.detail-contact-info{display:flex;align-items:center;gap:16px}.detail-avatar{width:56px;height:56px;border-radius:50%;background:#ececf0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-avatar span{font-size:18px;font-weight:500;color:#717182}.detail-contact-name{font-size:24px;font-weight:600;color:#0a0a0a}.detail-contact-rel{font-size:14px;color:#717182}.detail-contact-actions{display:flex;align-items:center;gap:8px}.btn-edit{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid rgba(0,0,0,.1);font-size:13px;font-weight:500;color:#0a0a0a;background:transparent;transition:background .15s}.btn-edit:hover{background:#f9fafb}.btn-delete{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid #fee2e2;font-size:13px;font-weight:500;color:#dc2626;background:transparent;transition:background .15s}.btn-delete:hover{background:#fef2f2}.detail-contact-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid #f3f4f6}.detail-meta-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#717182}.detail-meta-item a:hover{color:#0a0a0a}.section-card{background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 12px #0000000d;margin-bottom:20px;overflow:hidden}.section-header{padding:16px 24px;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between}.section-title-row{display:flex;align-items:center;gap:8px}.section-title{font-size:17px;font-weight:600;color:#0a0a0a}.section-count{font-size:12px;color:#717182;background:#f3f4f6;border-radius:999px;padding:2px 8px}.btn-section-add{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:none;font-size:13px;font-weight:500;color:#fff;background:#0a0a0a;transition:background .15s}.btn-section-add:hover{background:#333}.section-empty{padding:32px;text-align:center;color:#717182}.section-empty p{font-size:14px;margin-top:12px}.section-list{divide-y:1px solid #f9fafb}.idea-row{padding:16px 24px;transition:background .15s;border-bottom:1px solid #f9fafb}.idea-row:last-child{border-bottom:none}.idea-row:hover{background:#f9fafb80}.idea-row-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.idea-content{flex:1;min-width:0}.idea-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.idea-name{font-size:15px;font-weight:500;color:#0a0a0a}.status-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px}.status-badge.idea{background:#f3f4f6;color:#4b5563}.status-badge.purchased{background:#dbeafe;color:#1d4ed8}.status-badge.given{background:#d1fae5;color:#065f46}.idea-description{font-size:13px;color:#717182;margin-top:2px}.idea-meta{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap}.idea-price{font-size:13px;font-weight:500;color:#0a0a0a}.idea-event-tag{font-size:12px;color:#717182;background:#f3f4f6;padding:2px 8px;border-radius:999px}.idea-link{display:flex;align-items:center;gap:4px;font-size:12px;color:#2563eb}.idea-link:hover{text-decoration:underline}.idea-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.status-select{font-size:12px;border:1px solid #e5e7eb;border-radius:8px;padding:4px 8px;outline:none;background:#fff;cursor:pointer}.status-select:focus{box-shadow:0 0 0 2px #0000001a}.btn-icon{padding:6px;border-radius:8px;border:none;background:transparent;display:flex;align-items:center;transition:background .15s}.btn-icon:hover{background:#f3f4f6}.btn-icon.danger:hover{background:#fef2f2}.event-row{padding:16px 24px;border-bottom:1px solid #f9fafb}.event-row:last-child{border-bottom:none}.event-row-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.event-row-info{flex:1}.event-row-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.event-row-name{font-size:15px;font-weight:500;color:#0a0a0a}.event-type-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:8px;color:#fff;border:none}.event-row-date{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:13px;color:#717182}.event-row-notes{font-size:13px;color:#717182;margin-top:4px;font-style:italic}.budget-tracker{background:#f9fafb;border-radius:12px;padding:16px;margin-top:12px}.budget-tracker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.budget-tracker-title{font-size:13px;font-weight:500;color:#0a0a0a}.budget-tracker-count{font-size:12px;color:#717182}.budget-used-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.budget-used-label{font-size:13px;color:#717182}.budget-used-value{font-size:13px;font-weight:500}.budget-used-value.ok{color:#059669}.budget-used-value.warning{color:#d97706}.budget-used-value.over{color:#dc2626}.budget-used-total{font-weight:400;color:#717182}.budget-bar-track{height:6px;background:#f3f4f6;border-radius:999px;overflow:hidden}.budget-bar-fill{height:100%;border-radius:999px;transition:width .3s}.budget-bar-fill.ok{background:#10b981}.budget-bar-fill.warning{background:#f59e0b}.budget-bar-fill.over{background:#ef4444}.budget-over-msg{font-size:11px;color:#ef4444;margin-top:4px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;background:#00000080;padding:16px}.confirm-box{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;width:100%;max-width:384px;padding:24px}.confirm-title{font-size:16px;font-weight:600;color:#0a0a0a;margin-bottom:8px}.confirm-message{font-size:14px;color:#717182;margin-bottom:20px}.confirm-actions{display:flex;justify-content:flex-end;gap:12px}.btn-danger{padding:8px 16px;border-radius:8px;border:none;font-size:14px;font-weight:500;color:#fff;background:#ef4444;transition:background .15s}.btn-danger:hover{background:#dc2626}.btn-cancel{padding:8px 16px;border-radius:8px;border:1px solid rgba(0,0,0,.1);font-size:14px;font-weight:500;color:#0a0a0a;background:transparent;transition:background .15s}.btn-cancel:hover{background:#f9fafb}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#00000080;padding:16px}.modal-box{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;width:100%;max-width:448px;max-height:90vh;overflow-y:auto}.modal-header{padding:24px;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:20px;font-weight:600;color:#0a0a0a}.modal-subtitle{font-size:14px;color:#717182;margin-top:2px}.modal-close{padding:6px;border-radius:8px;border:none;background:transparent;color:#6b7280;display:flex;align-items:center;transition:background .15s}.modal-close:hover{background:#f3f4f6}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:0 24px 24px;display:flex;justify-content:flex-end;gap:12px}.form-group{display:flex;flex-direction:column;gap:8px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-label{font-size:14px;font-weight:500;color:#0a0a0a}.form-input{background:#f3f3f5;border:none;border-radius:8px;padding:8px 12px;font-size:14px;outline:none;width:100%;color:#0a0a0a}.form-input::placeholder{color:#717182}.form-input:focus{box-shadow:0 0 0 2px #0000001a}.form-input-date{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:8px 12px;font-size:14px;outline:none;width:100%;color:#0a0a0a}.form-input-date:focus{box-shadow:0 0 0 2px #0000001a}.form-input-prefix{position:relative}.form-input-prefix-symbol{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#717182;font-size:14px;pointer-events:none}.form-input-prefix .form-input{padding-left:28px}.form-select{background:#f3f3f5;border:none;border-radius:8px;padding:8px 12px;font-size:14px;outline:none;width:100%;color:#0a0a0a;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-select:focus{box-shadow:0 0 0 2px #0000001a}.form-textarea{background:#f3f3f5;border:none;border-radius:8px;padding:8px 12px;font-size:14px;outline:none;width:100%;resize:none;color:#0a0a0a}.form-textarea::placeholder{color:#717182}.form-textarea:focus{box-shadow:0 0 0 2px #0000001a}.form-error{font-size:12px;color:#ef4444}.btn-primary{padding:8px 16px;border-radius:8px;border:none;font-size:14px;font-weight:500;color:#fff;background:#0a0a0a;transition:background .15s}.btn-primary:hover{background:#333}.detail-not-found{min-height:100vh;background:#fff;padding-top:60px;display:flex;align-items:center;justify-content:center}.detail-not-found-inner{text-align:center}.detail-not-found-inner p{font-size:18px;color:#717182;margin-bottom:16px}.detail-not-found-inner button{font-size:14px;font-weight:500;color:#0a0a0a;background:none;border:none;text-decoration:underline}.page-container{min-height:100vh;background:#fff;padding-top:60px;display:flex;align-items:center;justify-content:center}.page-error{text-align:center}.page-error h1{font-size:30px;font-weight:600;color:#0a0a0a;margin-bottom:10px}.page-error p{font-size:16px;color:#717182}
