:root{--primary-contrast:#2c3e50;--secondary-contrast:#7f8c8d;--background:#fafafa;--background-gradient:linear-gradient(135deg,#fafafa,#f5f5f5);--surface:#fff;--border:#e0e0e0;--accent-primary:#9c88ff;--accent-secondary:#b39ddb;--accent-success:#66bb6a;--accent-warning:#ffa726;--button:#9c88ff;--button-hover:#8b75e8;--shadow:rgba(0,0,0,.08);--shadow-hover:rgba(0,0,0,.12)}.dark-theme{--primary-contrast:#eceff1;--secondary-contrast:#b0bec5;--background:#1a1a1a;--background-gradient:linear-gradient(135deg,#1a1a1a,#2c2c2c);--surface:#2c2c2c;--border:#424242;--accent-primary:#9c88ff;--accent-secondary:#b39ddb;--accent-success:#66bb6a;--accent-warning:#ffa726;--button:#9c88ff;--button-hover:#8b75e8;--shadow:rgba(0,0,0,.3);--shadow-hover:rgba(0,0,0,.4)}*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Pretendard,Apple SD Gothic Neo,sans-serif}html{background:var(--background)}body{color:var(--primary-contrast);background:var(--background-gradient);min-height:100dvh;flex-direction:column;justify-content:center}.header,body{display:flex;align-items:center}.header{width:100%;padding:24px 48px;justify-content:space-between;background:var(--surface);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{gap:24px;flex:1 1}.header .logo,.header-left{display:flex;align-items:center}.header .logo{font-size:24px;font-weight:700;color:var(--accent-primary);text-decoration:none;gap:8px;white-space:nowrap}.dday-container{gap:12px;flex-wrap:wrap}.dday-container,.dday-item{display:flex;align-items:center}.dday-item{gap:6px;padding:6px 12px;background:var(--background);border:1px solid var(--border);border-radius:16px;font-size:14px}.dday-title{color:var(--secondary-contrast);font-weight:500}.dday-count{color:var(--accent-primary);font-weight:700}.heading{font-size:56px;font-weight:700;letter-spacing:-.02em;text-align:center;color:var(--primary-contrast);line-height:1.2}.subheading{font-size:20px;font-weight:400;color:var(--secondary-contrast);text-align:center;line-height:1.6;max-width:600px;margin:0 auto}.regenerate-button{color:var(--background);background:var(--button)}.back-button{position:fixed;top:32px;left:32px;color:var(--primary-contrast);background-color:var(--surface);display:flex;align-items:center;gap:6px;text-decoration:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.button{font-size:16px;line-height:1.5;font-weight:600;padding:14px 32px;border-radius:12px;border:none;cursor:pointer;background:var(--button);color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px var(--shadow)}.button:hover{background:var(--button-hover);box-shadow:0 4px 16px var(--shadow-hover);transform:translateY(-2px)}.button:active{transform:translateY(0)}.button-secondary{background:transparent;color:var(--accent-primary);border:2px solid var(--accent-primary)}.button-secondary:hover{background:var(--accent-primary);color:#fff}.content{max-width:1200px;margin:0 auto;padding:80px 24px;gap:120px}.content,.hero{display:flex;flex-direction:column;align-items:center}.hero{gap:32px;text-align:center;padding:60px 0}.hero .buttons{display:flex;gap:16px;margin-top:16px}.section{width:100%;display:flex;flex-direction:column;align-items:center;gap:48px}.section-title{font-size:36px;text-align:center}.section-subtitle{font-size:18px;color:var(--secondary-contrast);text-align:center;max-width:700px}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:24px;gap:24px;width:100%}.features-three{grid-template-columns:repeat(3,1fr)}.card{background:var(--surface);border-radius:16px;padding:32px;display:flex;flex-direction:column;gap:16px;border:1px solid var(--border);box-shadow:0 4px 20px var(--shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-4px);box-shadow:0 8px 30px var(--shadow-hover)}.card-icon{font-size:40px;margin-bottom:8px}.card h2{font-size:22px;line-height:1.3;font-weight:600;color:var(--primary-contrast)}.card p{font-size:15px;line-height:1.7;color:var(--secondary-contrast)}.card p a,.link{color:var(--accent-primary);text-decoration:none;font-weight:500;transition:color .2s}.card p a:hover,.link:hover{color:var(--accent-secondary);text-decoration:underline}.header-actions{display:flex;align-items:center;gap:16px}.header-loading{font-size:14px;color:var(--secondary-contrast)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding-top:120px;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:16px;padding:32px;max-width:440px;width:90%;box-shadow:0 8px 40px var(--shadow-hover);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:24px;font-weight:700;color:var(--primary-contrast);margin:0}.modal-close{background:none;border:none;font-size:24px;color:var(--secondary-contrast);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:var(--border);color:var(--primary-contrast)}.modal-body{display:flex;flex-direction:column;gap:20px}.modal-description{color:var(--secondary-contrast);font-size:15px;line-height:1.6;margin:0}.login-options{display:flex;flex-direction:column;gap:16px}.divider{display:flex;align-items:center;text-align:center;color:var(--secondary-contrast);font-size:14px;margin:8px 0}.divider:after,.divider:before{content:"";flex:1 1;border-bottom:1px solid var(--border)}.divider span{padding:0 12px}.login-notice{font-size:13px;color:var(--secondary-contrast);text-align:center;margin:0;line-height:1.5}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.4}.google-button{background:#fff;color:#3c4043;border:1px solid #dadce0}.google-button:hover{background:#f8f9fa;box-shadow:0 1px 3px rgba(0,0,0,.1)}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:24px;cursor:pointer;transition:all .2s;font-size:14px;color:var(--primary-contrast)}.user-menu-button:hover{background:var(--background);border-color:var(--accent-primary)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;overflow:hidden}.user-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 24px var(--shadow-hover);min-width:280px;z-index:100;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:16px}.user-info{display:flex;flex-direction:column;gap:4px}.user-info-name{font-size:15px;font-weight:600;color:var(--primary-contrast)}.user-info-email{font-size:13px;color:var(--secondary-contrast)}.user-menu-divider{height:1px;background:var(--border);margin:0}.user-menu-items{padding:8px}.user-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:none;border:none;border-radius:8px;cursor:pointer;font-size:14px;color:var(--primary-contrast);text-align:left;transition:background .2s}.user-menu-item:hover:not(:disabled){background:var(--background)}.user-menu-item:disabled{opacity:.6;cursor:not-allowed}.user-menu-notice{padding:8px 12px;font-size:12px;color:var(--secondary-contrast);line-height:1.4}@media only screen and (max-width:768px){.heading{font-size:36px}.subheading{font-size:16px}.section-title{font-size:28px}.header{padding:16px 24px}.header .logo{font-size:20px}.content{padding:40px 16px;gap:80px}.hero{padding:40px 0}.hero .buttons{flex-direction:column;width:100%}.hero .buttons .button{width:100%}.features,.features-three{grid-template-columns:1fr}.card{padding:24px}.back-button{top:10px;left:10px}.modal-content{padding:24px}.modal-backdrop{padding-top:80px}.user-name{display:none}.user-menu-dropdown{right:-8px;min-width:260px}.header-left{flex-wrap:wrap}.dday-container{width:100%;order:2}}.dashboard-container{width:100%;min-height:calc(100vh - 80px);padding:40px 24px;background:var(--background)}.dashboard-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:40px}.dashboard-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 2px 8px var(--shadow)}.dashboard-title{font-size:32px;font-weight:700;color:var(--primary-contrast);margin-bottom:8px}.dashboard-subtitle{font-size:16px;color:var(--secondary-contrast);line-height:1.6}.section-title{font-size:24px;font-weight:700;color:var(--primary-contrast);margin-bottom:24px}.loading-container{padding:40px}.coming-soon{padding:40px;text-align:center;color:var(--secondary-contrast);background:var(--background);border-radius:12px;border:2px dashed var(--border)}.dday-manager{display:flex;flex-direction:column;gap:24px}.dday-form{padding:24px;background:var(--background);border:1px solid var(--border);border-radius:12px}.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:8px;flex:1 1;min-width:150px}.form-group label{font-weight:600}.form-group label,.form-input,.form-select{font-size:14px;color:var(--primary-contrast)}.form-input,.form-select{padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);transition:all .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(156,136,255,.1)}.empty-state{padding:60px 24px;text-align:center;color:var(--secondary-contrast)}.empty-state p:first-child{font-size:18px;font-weight:600;margin-bottom:8px}.empty-state p:last-child{font-size:14px}.dday-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:16px;gap:16px}.dday-card{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 4px var(--shadow);transition:all .2s;display:flex;flex-direction:column;gap:16px}.dday-card:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.dday-card-content{display:flex;flex-direction:column;gap:12px;flex:1 1}.dday-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.dday-card-title{font-size:20px;font-weight:700;color:var(--primary-contrast)}.dday-card-type{padding:4px 10px;background:var(--background);border:1px solid var(--border);border-radius:12px;font-size:12px;font-weight:600;color:var(--secondary-contrast)}.dday-card-date{font-size:14px;color:var(--secondary-contrast)}.dday-card-countdown{display:flex;align-items:baseline;gap:8px;margin-top:8px}.dday-card-count{font-size:32px;font-weight:800;color:var(--accent-primary)}.dday-card-days{font-size:14px;color:var(--secondary-contrast)}.dday-edit-form{display:flex;flex-direction:column;gap:12px}.dday-edit-form .form-row{flex-direction:column;align-items:stretch}.button-group{display:flex;gap:8px}.button-small{padding:8px 16px;font-size:14px}.button-secondary{background:var(--surface);border:1px solid var(--border);color:var(--primary-contrast)}.button-secondary:hover{background:var(--background);border-color:var(--accent-primary)}.button-danger{background:#ef5350;border:none;color:#fff}.button-danger:hover{background:#e53935}@media only screen and (max-width:768px){.dashboard-container,.dashboard-section{padding:24px 16px}.dashboard-title{font-size:24px}.section-title{font-size:20px}.form-row{flex-direction:column;align-items:stretch}.form-group{min-width:100%}.dday-list{grid-template-columns:1fr}.button-group{flex-direction:column}.button-group .button{width:100%}}.progress-summary{gap:24px}.progress-item,.progress-summary{display:flex;flex-direction:column}.progress-item{gap:8px}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:16px;font-weight:600;color:var(--primary-contrast)}.progress-percent{font-size:20px;font-weight:700;color:var(--accent-primary)}.progress-bar{width:100%;height:24px;background:var(--background);border:1px solid var(--border);border-radius:12px;overflow:hidden}.progress-fill{height:100%;transition:width .3s ease;border-radius:12px}.progress-fill.parenting{background:linear-gradient(90deg,#9c88ff,#b39ddb)}.progress-fill.moving{background:linear-gradient(90deg,#66bb6a,#81c784)}.tabs{display:flex;gap:8px;border-bottom:2px solid var(--border);margin-bottom:24px}.tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:600;color:var(--secondary-contrast);cursor:pointer;transition:all .2s;position:relative;bottom:-2px}.tab:hover{background:var(--background)}.tab.active,.tab:hover{color:var(--accent-primary)}.tab.active{border-bottom-color:var(--accent-primary)}.tab-content{animation:fadeIn .3s ease}.checklist-manager{display:flex;flex-direction:column;gap:24px}.checklist-header{display:flex;justify-content:flex-start;align-items:center;gap:12px;flex-wrap:wrap}.form-container{padding:24px;margin-bottom:24px}.checklist-filters,.form-container{background:var(--background);border:1px solid var(--border);border-radius:12px}.checklist-filters{display:flex;flex-wrap:wrap;gap:12px;padding:16px}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:14px;font-weight:600;color:var(--primary-contrast);white-space:nowrap}.search-group{flex:1 1;min-width:200px}.search-input{width:100%}.checklist-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:12px}.checklist-table{width:100%;border-collapse:collapse;background:var(--surface)}.checklist-table thead{background:var(--background);border-bottom:2px solid var(--border)}.checklist-table th{text-align:left;font-weight:700;white-space:nowrap}.checklist-table td,.checklist-table th{padding:12px 16px;font-size:14px;color:var(--primary-contrast)}.checklist-table td{border-bottom:1px solid var(--border)}.checklist-table tbody tr:last-child td{border-bottom:none}.checklist-table tbody tr:hover{background:var(--background)}.completed-row{opacity:.6}.completed-row td{color:var(--secondary-contrast)}.col-checkbox{width:60px;text-align:center}.checkbox-large{width:20px;height:20px;cursor:pointer}.col-title{min-width:150px;font-weight:600}.strikethrough{text-decoration:line-through}.col-category{min-width:100px}.category-badge{display:inline-block;padding:4px 10px;background:var(--background);border:1px solid var(--border);border-radius:12px;font-size:12px;font-weight:600;color:var(--secondary-contrast)}.col-quantity{width:80px;text-align:center}.col-vendor{min-width:120px}.col-duedate{min-width:130px}.col-cost{min-width:100px;text-align:right;font-weight:600}.col-notes{min-width:150px;max-width:250px}.notes-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-actions{width:150px}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.checklist-stats{padding:12px 16px;background:var(--background);border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--secondary-contrast);text-align:center}.checklist-form{display:flex;flex-direction:column;gap:24px}.form-title{font-size:20px;font-weight:700;color:var(--primary-contrast);margin:0}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:16px;gap:16px}.form-group.full-width{grid-column:1/-1}.form-group label{display:block;margin-bottom:6px}.form-group label.required:after{content:" *";color:#ef5350}.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:var(--surface);color:var(--primary-contrast);resize:vertical;transition:all .2s}.form-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(156,136,255,.1)}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border)}@media only screen and (max-width:768px){.progress-summary{gap:16px}.progress-label{font-size:14px}.progress-percent{font-size:16px}.tabs{overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 16px;font-size:14px;white-space:nowrap}.checklist-filters,.filter-group{flex-direction:column;align-items:stretch}.search-group{min-width:100%}.checklist-table-wrapper{border:none}.checklist-table,.checklist-table tbody,.checklist-table td,.checklist-table th,.checklist-table thead,.checklist-table tr{display:block}.checklist-table thead{display:none}.checklist-table tbody tr{margin-bottom:16px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 4px var(--shadow)}.checklist-table td{padding:8px 0;border:none;display:flex;justify-content:space-between;align-items:center}.checklist-table td:before{content:attr(data-label);font-weight:700;color:var(--secondary-contrast);margin-right:12px}.col-checkbox{width:100%;justify-content:flex-start}.col-actions{width:100%}.action-buttons{width:100%;justify-content:flex-end}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .button{width:100%}.checklist-stats{font-size:12px}}.template-selector{display:flex;flex-direction:column;gap:20px}.template-header{text-align:center}.template-title{font-size:22px;font-weight:700;color:var(--primary-contrast);margin-bottom:8px}.template-description{font-size:14px;color:var(--secondary-contrast)}.template-filters{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-radius:8px}.template-filters label{font-size:14px;font-weight:600;color:var(--primary-contrast)}.template-select-all{padding:12px 16px;background:var(--background);border:1px solid var(--border);border-radius:8px}.template-select-all label{display:flex;align-items:center;gap:8px;cursor:pointer}.template-select-all input[type=checkbox]{width:18px;height:18px;cursor:pointer}.template-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:4px}.template-item{display:flex;gap:12px;padding:16px;background:var(--background);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease}.template-item:hover{border-color:var(--primary);background:var(--surface)}.template-item.selected{border-color:var(--primary);background:rgba(74,158,255,.05)}.template-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.template-info{flex:1 1;display:flex;flex-direction:column;gap:8px}.template-item-title{font-size:16px;font-weight:600;color:var(--primary-contrast)}.template-item-details{display:flex;gap:16px;flex-wrap:wrap;font-size:13px}.template-subcategory{padding:4px 10px;background:var(--primary);color:#fff;border-radius:6px;font-size:12px;font-weight:600}.template-quantity{color:var(--secondary-contrast)}.template-cost{color:var(--primary);font-weight:600}.template-notes{font-size:13px;color:var(--secondary-contrast);font-style:italic}.template-footer{display:flex;flex-direction:column;gap:16px;padding-top:16px;border-top:2px solid var(--border)}.template-summary{display:flex;justify-content:space-between;gap:16px;padding:12px 16px;background:var(--surface);border-radius:8px;font-size:14px;font-weight:600}.template-summary span:last-child{color:var(--primary);font-size:16px}.template-actions{display:flex;gap:12px;justify-content:flex-end}@media only screen and (max-width:768px){.template-list{max-height:300px}.template-item{padding:12px}.template-item-details{flex-direction:column;gap:8px}.template-summary{flex-direction:column;text-align:center}.template-actions{flex-direction:column-reverse}.template-actions .button{width:100%}}.budget-tracker{display:flex;flex-direction:column;gap:24px}.budget-tracker-header{text-align:center}.budget-tracker-title{font-size:24px;font-weight:700;color:var(--primary-contrast);margin-bottom:8px}.budget-tracker-description{font-size:14px;color:var(--secondary-contrast)}.budget-tabs{display:flex;gap:8px;padding:4px;background:var(--background);border-radius:12px;border:1px solid var(--border)}.budget-tab{flex:1 1;padding:12px 16px;background:transparent;border:none;border-radius:8px;font-size:14px;font-weight:600;color:var(--secondary-contrast);cursor:pointer;transition:all .2s ease}.budget-tab:hover{background:var(--surface);color:var(--primary-contrast)}.budget-tab.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(74,158,255,.3)}.budget-tab-content{min-height:300px}.budget-card{padding:24px;background:var(--background);border:2px solid var(--border);border-radius:16px;transition:all .3s ease}.budget-card:hover{box-shadow:0 4px 12px var(--shadow)}.budget-card-safe{border-color:#10b981}.budget-card-warning{border-color:#f59e0b}.budget-card-danger{border-color:#ef4444}.budget-card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.budget-category-icon{font-size:28px}.budget-category-title{font-size:20px;font-weight:700;color:var(--primary-contrast)}.budget-amounts{display:flex;justify-content:space-between;gap:16px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.budget-amount-item{display:flex;flex-direction:column;gap:4px;flex:1 1}.budget-amount-label{font-size:12px;font-weight:600;color:var(--secondary-contrast);text-transform:uppercase}.budget-amount-value{font-size:18px;font-weight:700}.budget-estimated{color:var(--primary)}.budget-actual{color:#10b981}.budget-remaining{color:#6366f1}.budget-over{color:#ef4444}.budget-progress-section{margin-bottom:16px}.budget-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.budget-progress-label{font-size:13px;font-weight:600;color:var(--secondary-contrast)}.budget-progress-percent{font-size:16px;font-weight:700;color:var(--primary-contrast)}.budget-progress-bar{height:12px;background:var(--surface);border-radius:6px;overflow:hidden}.budget-progress-fill{height:100%;border-radius:6px;transition:width .5s ease}.budget-progress-safe{background:linear-gradient(90deg,#10b981,#34d399)}.budget-progress-warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.budget-progress-danger{background:linear-gradient(90deg,#ef4444,#f87171)}.budget-items-summary{display:flex;justify-content:space-between;align-items:center}.budget-items-text{font-size:13px;color:var(--secondary-contrast)}.budget-caution-badge,.budget-warning-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.budget-warning-badge{background:rgba(239,68,68,.1);color:#ef4444}.budget-caution-badge{background:rgba(245,158,11,.1);color:#f59e0b}.budget-summary-container{display:flex;flex-direction:column;gap:20px}.budget-categories{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:20px;gap:20px}.budget-empty-state{padding:60px 20px;text-align:center;background:var(--background);border:2px dashed var(--border);border-radius:16px;color:var(--secondary-contrast)}.budget-empty-state p{margin:8px 0}.budget-detail{display:flex;flex-direction:column;gap:20px;padding:24px;background:var(--background);border:1px solid var(--border);border-radius:16px}.budget-detail-header{display:flex;justify-content:space-between;align-items:center}.budget-detail-title{font-size:18px;font-weight:700;color:var(--primary-contrast)}.budget-detail-summary{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;padding:20px;background:var(--surface);border-radius:12px}.budget-detail-summary-item{display:flex;flex-direction:column;gap:8px}.budget-detail-label{font-size:12px;font-weight:600;color:var(--secondary-contrast);text-transform:uppercase}.budget-detail-value{font-size:20px;font-weight:700}.budget-detail-list{display:flex;flex-direction:column;gap:12px}.budget-detail-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s ease}.budget-detail-item:hover{box-shadow:0 2px 8px var(--shadow)}.budget-detail-item-header{display:flex;justify-content:space-between;align-items:center;padding:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.budget-detail-item-header:hover{background:var(--background)}.budget-detail-item-left{display:flex;align-items:center;gap:12px}.budget-detail-icon{font-size:12px;color:var(--secondary-contrast);transition:transform .2s ease}.budget-detail-item.expanded .budget-detail-icon{transform:rotate(0deg)}.budget-detail-subcategory{font-size:15px;font-weight:600;color:var(--primary-contrast)}.budget-detail-count{font-size:13px;color:var(--secondary-contrast)}.budget-detail-item-right{display:flex;align-items:center;gap:12px}.budget-detail-amount{font-size:14px;font-weight:600;color:var(--primary-contrast)}.budget-over-badge{padding:4px 10px;background:rgba(239,68,68,.1);color:#ef4444;border-radius:8px;font-size:12px;font-weight:600}.budget-detail-item-content{padding:0 16px 16px;display:flex;flex-direction:column;gap:12px}.budget-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.budget-detail-row-label{font-size:13px;color:var(--secondary-contrast)}.budget-detail-row-value{font-size:14px;font-weight:600;color:var(--primary-contrast)}.budget-detail-row-value.text-success{color:#10b981}.budget-detail-row-value.text-danger{color:#ef4444}.budget-detail-progress{margin-top:8px}.budget-info{padding:16px;background:rgba(74,158,255,.05);border:1px solid rgba(74,158,255,.2);border-radius:12px;font-size:13px;color:var(--secondary-contrast);line-height:1.6}.budget-info strong{color:var(--primary)}@media only screen and (max-width:768px){.budget-tracker-title{font-size:20px}.budget-tabs{flex-direction:column}.budget-tab{padding:10px 12px;font-size:13px}.budget-categories{grid-template-columns:1fr}.budget-amounts{flex-direction:column;gap:12px}.budget-amount-value{font-size:16px}.budget-card{padding:16px}.budget-detail-summary{grid-template-columns:1fr;gap:12px}.budget-detail{padding:16px}.budget-detail-item-header{flex-direction:column;align-items:flex-start;gap:8px}.budget-detail-item-right{width:100%;justify-content:space-between}.budget-info{font-size:12px}}.budget-goal-form{margin-bottom:20px}.budget-goal-display{display:flex;justify-content:center;align-items:center}.budget-goal-current{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:rgba(99,102,241,.05);border:2px solid rgba(99,102,241,.2);border-radius:12px;width:100%}.budget-goal-label{font-size:13px;font-weight:600;color:var(--secondary-contrast);text-transform:uppercase}.budget-goal-amount{font-size:24px;font-weight:700;color:#6366f1}.budget-goal-actions{display:flex;gap:8px}.budget-goal-input{padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.budget-goal-input .form-group{margin-bottom:16px}.budget-goal-input .form-actions{display:flex;gap:12px;justify-content:flex-end}@media only screen and (max-width:768px){.budget-goal-current{padding:16px}.budget-goal-amount{font-size:20px}.budget-goal-actions{width:100%;justify-content:center}.budget-goal-input .form-actions{flex-direction:column-reverse}.budget-goal-input .form-actions .button{width:100%}}.profile-container{min-height:100vh;padding:40px 20px;background:var(--background)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--secondary-contrast)}.profile-content{max-width:800px;margin:0 auto}.profile-title{font-size:32px;font-weight:700;color:var(--primary-contrast);margin-bottom:32px;text-align:center}.profile-form{display:flex;flex-direction:column;gap:32px}.profile-section{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.form-help{font-size:12px;color:var(--secondary-contrast);margin-top:4px}.twins-list{display:flex;flex-direction:column;gap:16px}.twin-card{padding:20px;background:var(--background);border:2px solid var(--border);border-radius:12px;transition:all .2s ease}.twin-card:hover{border-color:var(--primary);box-shadow:0 2px 8px var(--shadow)}.twin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.twin-order{font-size:16px;font-weight:700;color:var(--primary);padding:6px 16px;background:rgba(74,158,255,.1);border-radius:20px}.twin-form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.gender-options{display:flex;gap:12px;flex-wrap:wrap}.radio-label{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--background);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:600}.radio-label:hover{border-color:var(--primary);background:var(--surface)}.radio-label input[type=radio]{cursor:pointer;width:16px;height:16px}.radio-label input[type=radio]:checked+span{color:var(--primary)}.radio-label:has(input[type=radio]:checked){border-color:var(--primary);background:rgba(74,158,255,.1)}.profile-actions{display:flex;gap:16px;justify-content:flex-end;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:16px}.profile-actions .button{min-width:120px}.success-message{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);border-radius:12px;color:#10b981;font-weight:600;animation:fadeIn .3s ease}.profile-section .empty-state{padding:40px 20px;text-align:center;background:var(--background);border:2px dashed var(--border);border-radius:12px;color:var(--secondary-contrast)}.profile-section .empty-state p{margin:8px 0}@media only screen and (max-width:768px){.profile-container{padding:20px 16px}.profile-title{font-size:24px;margin-bottom:24px}.profile-form{gap:20px}.profile-section{padding:16px}.section-header{flex-direction:column;align-items:stretch;gap:12px}.section-header .button{width:100%}.twin-card{padding:16px}.twin-form-grid{grid-template-columns:1fr;gap:12px}.gender-options{flex-direction:column}.radio-label{width:100%;justify-content:center}.profile-actions{flex-direction:column-reverse;padding:16px}.profile-actions .button{width:100%;min-width:auto}}.profile-nav{margin-bottom:20px}.nav-button{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;color:var(--primary-contrast);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.nav-button:hover{background:var(--surface);border-color:var(--accent-primary);color:var(--accent-primary);box-shadow:0 2px 8px var(--shadow)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.profile-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 8px var(--shadow)}.profile-button:hover{background:var(--button-hover);box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-1px)}.profile-button:active{transform:translateY(0);box-shadow:0 2px 6px var(--shadow)}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:16px}.nav-button,.profile-button{width:100%;justify-content:center}}.invite-code-manager{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.invite-header{margin-bottom:24px}.invite-title{font-size:18px;font-weight:700;color:var(--primary-contrast);margin-bottom:8px}.invite-subtitle{font-size:14px;color:var(--secondary-contrast)}.members-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.members-title{font-size:14px;font-weight:600;color:var(--primary-contrast);margin-bottom:12px}.members-list{display:flex;flex-direction:column;gap:12px}.member-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--background);border-radius:8px}.member-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.member-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.member-info{flex:1 1}.member-name{font-size:14px;font-weight:600;color:var(--primary-contrast);margin-bottom:2px}.member-email{font-size:12px;color:var(--secondary-contrast)}.invite-code-section{padding:20px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:12px;color:#fff}.code-container{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.code-display{flex:1 1;display:flex;flex-direction:column;gap:4px}.code-label{font-size:12px;opacity:.9}.code-value{font-size:28px;font-weight:700;letter-spacing:4px;font-family:Courier New,monospace}.copy-button{padding:10px 20px;background:hsla(0,0%,100%,.2);color:#fff;border:1px solid hsla(0,0%,100%,.3);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.copy-button:hover{background:hsla(0,0%,100%,.3)}.copy-button:disabled{opacity:.5;cursor:not-allowed}.code-expiry{font-size:13px;opacity:.9;margin-bottom:8px}.code-help{font-size:13px;opacity:.85;line-height:1.5}.share-actions{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:8px;gap:8px;margin:16px 0}.share-button{padding:12px 16px;border:1px solid hsla(0,0%,100%,.3);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.share-button.primary{background:hsla(0,0%,100%,.95);color:var(--primary);border-color:transparent}.share-button.primary:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.share-button.secondary{background:hsla(0,0%,100%,.2);color:#fff;border-color:hsla(0,0%,100%,.3)}.share-button.secondary:hover{background:hsla(0,0%,100%,.3)}.share-button:disabled{opacity:.5;cursor:not-allowed}.code-help-section{margin-top:16px;padding-top:16px;border-top:1px solid hsla(0,0%,100%,.2)}.code-help-title{font-size:14px;font-weight:600;margin-bottom:8px;opacity:.95}.code-help-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.code-help-list li{font-size:13px;opacity:.85;line-height:1.5;padding-left:16px;position:relative}.code-help-list li:before{content:"•";position:absolute;left:0;font-weight:700}.code-help-list li strong{font-weight:600;opacity:1}.info-message{background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:12px 16px;margin-bottom:16px}.info-message p{color:var(--primary);font-size:14px;font-weight:600;margin:0}.no-code-section{text-align:center;padding:40px 20px}.no-code-message{font-size:14px;color:var(--secondary-contrast);margin-bottom:20px}.create-button{padding:12px 32px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.create-button:hover{background:var(--button-hover);box-shadow:0 4px 12px var(--shadow-hover)}.create-button:disabled{opacity:.5;cursor:not-allowed}.join-space-form{padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.join-header{margin-bottom:24px}.join-title{font-size:18px;font-weight:700;color:var(--primary-contrast);margin-bottom:8px}.join-subtitle{font-size:14px;color:var(--secondary-contrast)}.join-form{display:flex;flex-direction:column;gap:20px}.code-input{font-size:20px;font-weight:600;letter-spacing:4px;text-align:center;font-family:Courier New,monospace;text-transform:uppercase}.submit-button{padding:14px 32px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.submit-button:hover:not(:disabled){background:var(--button-hover);box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-1px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.success-message{padding:16px;background:rgba(102,187,106,.1);border:1px solid var(--accent-success);border-radius:8px;text-align:center}.success-message p{color:var(--accent-success);font-weight:600;margin-bottom:4px}.success-sub{font-size:13px;font-weight:400;opacity:.8}.invite-section{margin-bottom:24px}@media (max-width:768px){.code-container{flex-direction:column;align-items:stretch}.code-value{font-size:24px}.copy-button{width:100%}.share-actions{grid-template-columns:1fr;gap:10px}.share-button{width:100%;padding:14px 16px}.code-help-list li{font-size:12px}.invite-code-section{padding:16px}}.activity-feed{background:var(--card-background);border-radius:12px;padding:24px;border:1px solid var(--border)}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.activity-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.activity-filters{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:6px 12px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--secondary-contrast);font-size:14px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:rgba(139,92,246,.1);border-color:var(--primary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.activity-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:16px}.activity-loading .spinner{width:32px;height:32px;border:3px solid rgba(139,92,246,.1);border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}.activity-loading p{color:var(--secondary-contrast);font-size:14px}.activity-empty{text-align:center;padding:40px 20px;color:var(--secondary-contrast)}.activity-empty p{margin:4px 0}.activity-empty-sub{font-size:14px;opacity:.7}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;gap:12px;padding:16px;background:var(--background);border-radius:8px;border:1px solid var(--border);transition:all .2s}.activity-item:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(139,92,246,.1)}.activity-icon{font-size:24px;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(139,92,246,.1);border-radius:8px}.activity-content{flex:1 1;min-width:0}.activity-main{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px}.activity-user{font-weight:600;color:var(--text-primary)}.activity-action{color:var(--secondary-contrast);font-size:14px}.activity-item-title{font-size:14px;color:var(--primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-details{font-size:13px;color:var(--secondary-contrast);opacity:.8}.activity-time{font-size:12px;color:var(--secondary-contrast);white-space:nowrap;flex-shrink:0;align-self:flex-start;opacity:.7}.activity-footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);text-align:center}.activity-footer-text{font-size:13px;color:var(--secondary-contrast);opacity:.7;margin:0}@media only screen and (max-width:768px){.activity-feed{padding:16px}.activity-header{flex-direction:column;align-items:flex-start}.activity-filters{width:100%;overflow-x:auto;padding-bottom:4px}.activity-item{padding:12px;gap:10px}.activity-icon{width:32px;height:32px;font-size:20px}.activity-main{flex-direction:column;align-items:flex-start;gap:4px}.activity-time{align-self:flex-end}}