@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;900&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--ink:#1a1a2e;--paper:#f5f0e8;--cream:#faf7f2;--gold:#c9a84c;--gold-light:#e8d5a3;--rust:#b5541e;--sage:#4a7c59;--muted:#8a8070;--border:#d4c9b5;--card:#fff;--shadow:0 4px 24px #1a1a2e1a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--paper);color:var(--ink);min-height:100vh;font-family:DM Sans,sans-serif}.app-header{background:var(--ink);z-index:100;justify-content:space-between;align-items:center;padding:22px 40px;display:flex;position:sticky;top:0}.app-header .logo{color:var(--gold);letter-spacing:.02em;font-family:Playfair Display,serif;font-size:1.45rem}.app-header .logo span{color:#fff}.step-pills{gap:8px;display:flex}.step-pill{letter-spacing:.08em;text-transform:uppercase;color:#fff6;border:1.5px solid #ffffff2e;border-radius:20px;padding:6px 14px;font-size:.72rem;font-weight:600;transition:all .3s}.step-pill.active{background:var(--gold);color:var(--ink);border-color:var(--gold)}.step-pill.done{border-color:var(--sage);color:var(--sage)}.main{max-width:960px;margin:0 auto;padding:40px 24px 80px}.step-panel{animation:.4s fadeIn;display:none}.step-panel.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.intro-hero{text-align:center;padding:50px 0 40px}.intro-hero h1{color:var(--ink);margin-bottom:16px;font-family:Playfair Display,serif;font-size:3.2rem;font-weight:900;line-height:1.1}.intro-hero h1 em{color:var(--gold);font-style:normal}.intro-hero p{color:var(--muted);max-width:500px;margin:0 auto 36px;font-size:1.1rem;line-height:1.7}.info-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px;display:grid}.info-field label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:.78rem;font-weight:600;display:block}.info-field input,.info-field select{border:1.5px solid var(--border);background:var(--card);width:100%;color:var(--ink);border-radius:10px;outline:none;padding:13px 16px;font-family:DM Sans,sans-serif;font-size:1rem;transition:border-color .2s}.info-field input:focus,.info-field select:focus{border-color:var(--gold)}.categories-header{justify-content:space-between;align-items:baseline;margin-bottom:28px;display:flex}.categories-header h2{font-family:Playfair Display,serif;font-size:2rem;font-weight:700}.categories-header p{color:var(--muted);font-size:.92rem}.category-tabs{flex-wrap:wrap;gap:8px;margin-bottom:28px;display:flex}.cat-tab{border:1.5px solid var(--border);background:var(--card);cursor:pointer;color:var(--ink);border-radius:8px;padding:8px 18px;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;transition:all .2s;position:relative}.cat-tab:hover{border-color:var(--gold)}.cat-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}.cat-tab .badge{background:var(--gold);color:var(--ink);text-align:center;border-radius:10px;min-width:18px;padding:1px 6px;font-size:.65rem;font-weight:700;position:absolute;top:-6px;right:-6px}.cat-panel{display:none}.cat-panel.active{display:block}.cat-icon-header{align-items:center;gap:14px;margin-bottom:20px;display:flex}.cat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex}.cat-icon-header h3{font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700}.cat-icon-header p{color:var(--muted);font-size:.85rem}.entries-list{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.entry-row{background:var(--card);border:1.5px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:4px 10px 4px 14px;transition:border-color .2s;display:flex}.entry-row:focus-within{border-color:var(--gold)}.entry-row input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-family:DM Sans,sans-serif;font-size:.97rem}.entry-row .del-btn{cursor:pointer;color:#ccc;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:1.1rem;transition:color .2s}.entry-row .del-btn:hover{color:var(--rust)}.add-entry-btn{border:1.5px dashed var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:10px;align-items:center;gap:8px;width:100%;padding:11px 18px;font-family:DM Sans,sans-serif;font-size:.92rem;transition:all .2s;display:flex}.add-entry-btn:hover{border-color:var(--gold);color:var(--gold)}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:13px 28px;font-family:DM Sans,sans-serif;font-size:.97rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover{background:#2d2d4e;transform:translateY(-1px);box-shadow:0 6px 20px #1a1a2e38}.btn-gold{background:var(--gold);color:var(--ink)}.btn-gold:hover{background:#b8923e;transform:translateY(-1px);box-shadow:0 6px 20px #c9a84c59}.btn-outline{border:1.5px solid var(--border);color:var(--ink);background:0 0}.btn-outline:hover{border-color:var(--ink)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.action-row{border-top:1.5px solid var(--border);justify-content:space-between;align-items:center;margin-top:36px;padding-top:24px;display:flex}.image-upload-container{border:1.5px dashed var(--border);text-align:center;background:var(--card);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;min-height:140px;padding:24px;transition:all .2s;display:flex}.image-upload-container:hover{border-color:var(--gold);background:#fffdf9}.upload-placeholder{flex-direction:column;align-items:center;gap:8px;display:flex}.upload-icon{font-size:2rem}.upload-placeholder p{color:var(--muted);margin:0;font-size:.88rem}.preview-container{width:100px;height:100px;position:relative}.profile-preview{object-fit:cover;border:3px solid var(--gold);border-radius:8px;width:100%;height:100%;box-shadow:0 4px 12px #0000001a}.remove-img-btn{background:var(--rust);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.8rem;transition:transform .2s;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 6px #0003}.remove-img-btn:hover{transform:scale(1.1)}.processing-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.spinner-ring{border:4px solid var(--gold-light);border-top-color:var(--gold);border-radius:50%;width:64px;height:64px;margin-bottom:28px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.processing-center h3{margin-bottom:10px;font-family:Playfair Display,serif;font-size:1.5rem}.processing-center p{color:var(--muted);font-size:.95rem}.processing-steps{text-align:left;margin-top:28px}.proc-step{color:var(--muted);align-items:center;gap:12px;padding:8px 0;font-size:.92rem;transition:color .4s;display:flex}.proc-step.done{color:var(--sage)}.proc-step.active{color:var(--ink);font-weight:500}.proc-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:10px;height:10px;transition:background .4s}.proc-step.done .proc-dot{background:var(--sage)}.proc-step.active .proc-dot{background:var(--gold);animation:1s infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.4)}}.chart-header-section{text-align:center;margin-bottom:40px}.chart-header-section h2{color:var(--ink);font-family:Playfair Display,serif;font-size:2.4rem;font-weight:900}.chart-header-section p{color:var(--muted);margin-top:6px}.quarter-block{margin-bottom:48px}.quarter-label{align-items:center;gap:14px;margin-bottom:20px;display:flex}.quarter-label .q-badge{background:var(--ink);color:var(--gold);letter-spacing:.08em;border-radius:6px;padding:5px 14px;font-family:Playfair Display,serif;font-size:.9rem;font-weight:700}.quarter-label .q-months{color:var(--muted);font-size:.85rem}.quarter-divider{background:linear-gradient(90deg, var(--gold), transparent);height:2px;margin-bottom:24px}.months-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.month-card{background:var(--card);border:1.5px solid var(--border);box-shadow:var(--shadow);border-radius:14px;padding:20px;transition:box-shadow .2s}.month-card:hover{box-shadow:0 8px 32px #1a1a2e24}.month-name{color:var(--ink);border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:10px;font-family:Playfair Display,serif;font-size:1.15rem;font-weight:700}.entry-group{margin-bottom:14px}.entry-group:last-child{margin-bottom:0}.entry-type-label{letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-size:.68rem;font-weight:700}.entry-type-label.goal{color:var(--sage)}.entry-type-label.action{color:var(--rust)}.editable-entry{background:#faf9f6;border:1px solid #0000;border-radius:8px;align-items:flex-start;gap:8px;margin-bottom:6px;padding:8px 10px;transition:border-color .2s;display:flex}.editable-entry:focus-within{border-color:var(--gold);background:#fff}.entry-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:7px}.entry-dot.goal{background:var(--sage)}.entry-dot.action{background:var(--rust)}.editable-entry textarea{color:var(--ink);resize:none;background:0 0;border:none;outline:none;flex:1;min-height:36px;font-family:DM Sans,sans-serif;font-size:.85rem;line-height:1.5}.empty-month{color:var(--muted);padding:6px 0;font-size:.82rem;font-style:italic}.toast{background:var(--ink);color:#fff;z-index:999;pointer-events:none;border-radius:10px;padding:12px 24px;font-size:.9rem;transition:transform .3s;position:fixed;bottom:30px;left:50%;transform:translate(-50%)translateY(80px)}.toast.show{transform:translate(-50%)translateY(0)}.reset-btn{color:#ffffff8c;letter-spacing:.06em;cursor:pointer;background:0 0;border:1.5px solid #fff3;border-radius:8px;padding:6px 14px;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;transition:all .2s}.reset-btn:hover{border-color:var(--rust);color:#e07a5f}.confirm-overlay{z-index:300;background:#00000080;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.confirm-overlay.show{display:flex}.confirm-box{background:var(--card);text-align:center;border-radius:16px;width:90%;max-width:380px;padding:36px 32px;box-shadow:0 24px 80px #00000040}.confirm-box h3{margin-bottom:10px;font-family:Playfair Display,serif;font-size:1.3rem}.confirm-box p{color:var(--muted);margin-bottom:28px;font-size:.92rem;line-height:1.6}.confirm-btns{justify-content:center;gap:12px;display:flex}.saved-dot{color:var(--sage);opacity:0;align-items:center;gap:5px;font-size:.72rem;font-weight:500;transition:opacity .4s;display:inline-flex}.saved-dot.show{opacity:1}.saved-dot:before{content:"";background:var(--sage);border-radius:50%;width:6px;height:6px;display:inline-block}@media (width<=640px){.info-grid,.months-grid{grid-template-columns:1fr}.app-header{padding:16px 20px}.main{padding:24px 16px 80px}.intro-hero h1{font-size:2rem}.step-pills{display:none}}.app-footer{background:var(--ink);color:var(--paper);border-top:1px solid var(--border);margin-top:60px;padding:24px 0}.footer-content{justify-content:space-between;align-items:center;width:100%;padding:0 40px;font-size:.9rem;display:flex}.powered-by{color:var(--muted)}.powered-by a{text-decoration:none}.powered-by strong{color:var(--gold);font-weight:600}@media (width<=600px){.footer-content{text-align:center;flex-direction:column;gap:12px}}
