@charset "UTF-8";.header{width:100%;padding:2rem 1.5rem;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;text-align:center;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:2rem}.header__content{max-width:800px;margin:0 auto}.header__title{font-size:2.5rem;margin-bottom:.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}@media (max-width: 768px){.header__title{font-size:2rem}}@media (max-width: 480px){.header__title{font-size:1.75rem}}.header__subtitle{font-size:1.125rem;margin-bottom:2rem;opacity:.9;font-weight:400}@media (max-width: 768px){.header__subtitle{font-size:1rem}}@media (max-width: 480px){.header__subtitle{font-size:.875rem}}.header__date-input{background-color:#ffffff1a;padding:1.5rem;border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}@media (max-width: 480px){.header__date-input{padding:1rem}}.header__label{display:block;font-size:1rem;margin-bottom:1rem;font-weight:500}@media (max-width: 480px){.header__label{font-size:.875rem}}.header__input-group{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}@media (max-width: 480px){.header__input-group{flex-direction:column;align-items:stretch}}.header__input{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:.5rem;background-color:#ffffffe6;color:#1f2937;font-size:1rem;min-width:200px}.header__input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #ffffff4d}@media (max-width: 480px){.header__input{min-width:auto;width:100%}}.header__button{padding:.5rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s ease}@media (max-width: 480px){.header__button{width:100%}}.header__button--primary{background-color:#ffffffe6;color:#f59e0b}.header__button--primary:hover:not(:disabled){background-color:#fff;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.header__button--secondary{background-color:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}.header__button--secondary:hover:not(:disabled){background-color:#ffffff1a;border-color:#fff;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.header__button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.header__info{margin-top:1.5rem;padding:1rem;background-color:#ffffff1a;border-radius:.5rem;border:1px solid rgba(255,255,255,.2)}.header__info p{margin:.25rem 0;font-size:.9rem}.header__info p strong{font-weight:600}@media (max-width: 480px){.header__info{font-size:.875rem}}.week-grid-container{width:100%;padding:1.5rem;background-color:#f9fafb;border-radius:1rem;box-shadow:0 1px 2px #0000000d;margin-bottom:2rem;overflow-x:auto}.week-grid-title{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem;text-align:center}.week-grid{display:grid;grid-template-columns:repeat(64,minmax(8px,1fr));grid-template-rows:repeat(auto-fill,minmax(8px,1fr));gap:1px;background-color:#e5e7eb;border-radius:.25rem;overflow:hidden;width:fit-content;max-width:100%}@media (max-width: 768px){.week-grid{grid-template-columns:repeat(32,minmax(6px,1fr));grid-template-rows:repeat(auto-fill,minmax(6px,1fr));gap:.5px}}@media (max-width: 480px){.week-grid{grid-template-columns:repeat(24,minmax(5px,1fr));grid-template-rows:repeat(auto-fill,minmax(5px,1fr))}}.week-grid__cell{position:relative;width:10px;height:10px;transition:all .15s ease;cursor:pointer}@media (max-width: 768px){.week-grid__cell{width:8px;height:8px}}@media (max-width: 480px){.week-grid__cell{width:6px;height:6px}}.week-grid__cell:hover{transform:scale(1.2);z-index:10;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.week-grid__cell--stage-1{background-color:#fef3c7}.week-grid__cell--stage-2{background-color:#dbeafe}.week-grid__cell--stage-3{background-color:#d1fae5}.week-grid__cell--past{background-color:#f59e0b;opacity:.8}.week-grid__cell--current{background-color:#ef4444;opacity:1;box-shadow:0 0 0 1px #ef444480}.week-grid__cell--future{opacity:.6}.week-grid__cell--has-milestone{position:relative}.week-grid__cell--has-milestone:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60%;height:60%;background-color:#8b5cf6;border-radius:50%;opacity:.8}@media (max-width: 768px){.week-grid__cell--has-milestone:after{width:50%;height:50%}}.milestone-indicator{position:absolute;top:1px;right:1px;width:3px;height:3px;background-color:#8b5cf6;border-radius:50%}@media (max-width: 768px){.milestone-indicator{width:2px;height:2px}}.week-grid__tooltip{position:fixed;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:1000;width:250px;pointer-events:none;font-size:.875rem;transform:translateY(-50%)}@media (max-width: 768px){.week-grid__tooltip{width:200px;font-size:.75rem;padding:.5rem}}.week-grid__tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.week-grid__tooltip-header h4{margin:0;font-size:1rem;color:#1f2937}.week-grid__stage-badge{padding:2px 6px;border-radius:.25rem;font-size:.75rem;font-weight:600;color:#1f2937}.week-grid__stage-badge.stage-1{background-color:#fef3c7}.week-grid__stage-badge.stage-2{background-color:#dbeafe}.week-grid__stage-badge.stage-3{background-color:#d1fae5}.week-grid__date-range{margin:0 0 .25rem;color:#6b7280;font-weight:500}.week-grid__stage-desc{margin:0 0 .5rem;color:#9ca3af;font-size:.75rem}.week-grid__milestones{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e5e7eb}.week-grid__milestones h5{margin:0 0 .25rem;font-size:.875rem;color:#1f2937}.week-grid__milestones ul{list-style:none;padding:0;margin:0}.week-grid__milestone-item{display:flex;align-items:center;margin-bottom:.25rem;font-size:.75rem}.week-grid__milestone-item .milestone-category{width:8px;height:8px;border-radius:50%;margin-right:.25rem}.week-grid__milestone-item .milestone-category.category-family{background-color:#10b981}.week-grid__milestone-item .milestone-category.category-career{background-color:#3b82f6}.week-grid__milestone-item .milestone-category.category-health{background-color:#f59e0b}.week-grid__milestone-item .milestone-category.category-education{background-color:#8b5cf6}.week-grid__milestone-item .milestone-category.category-other{background-color:#9ca3af}.week-grid-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#6b7280}.legend-color{width:16px;height:16px;border-radius:.25rem}.legend-color.past{background-color:#f59e0b}.legend-color.current{background-color:#ef4444}.legend-color.future{background-color:#f3f4f6;opacity:.8}.legend-color.milestone{background-color:#8b5cf6}.life-stages{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;flex-wrap:wrap}.life-stage{flex:1;min-width:200px;padding:1.5rem;background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;text-align:center;transition:all .15s ease}.life-stage:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.life-stage h3{margin:0 0 .5rem;font-size:1.125rem;color:#1f2937}.life-stage p{margin:0 0 .5rem;font-size:.875rem;color:#6b7280}.life-stage.stage-1{border-top:3px solid #fef3c7}.life-stage.stage-2{border-top:3px solid #dbeafe}.life-stage.stage-3{border-top:3px solid #d1fae5}.stage-percentage{display:inline-block;padding:.25rem .5rem;background-color:#f9fafb;border-radius:.25rem;font-size:.875rem;font-weight:600;color:#f59e0b}.stats-display{width:100%;padding:1.5rem;background-color:#fff;border-radius:1rem;box-shadow:0 1px 2px #0000000d;margin-bottom:2rem}.stats-display--empty{text-align:center;color:#6b7280;font-style:italic;padding:2rem}.stats-display__title{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem;text-align:center}.stats-display__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}@media (max-width: 768px){.stats-display__grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}}@media (max-width: 480px){.stats-display__grid{grid-template-columns:1fr}}.stats-card{background-color:#f9fafb;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 2px #0000000d;transition:all .15s ease;display:flex;align-items:center;gap:1rem}.stats-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}@media (max-width: 480px){.stats-card{flex-direction:column;text-align:center}}.stats-card__icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stats-card__icon--lived{background-color:#f59e0b1a;color:#f59e0b}.stats-card__icon--remaining{background-color:#3b82f61a;color:#3b82f6}.stats-card__icon--progress{background-color:#10b9811a;color:#10b981}.stats-card__icon--percentage{background-color:#8b5cf61a;color:#8b5cf6}.stats-card__icon svg{width:24px;height:24px}.stats-card__content{flex:1}.stats-card__title{font-size:.875rem;color:#6b7280;margin-bottom:.25rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stats-card__value{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.stats-card__value--large{font-size:2rem}.stats-card__value--small{font-size:1.25rem}.stats-card__description{font-size:.875rem;color:#9ca3af}.stats-card__progress{width:100%;height:8px;background-color:#fff;border-radius:4px;overflow:hidden;margin:.5rem 0}.stats-card__progress-bar{height:100%;background:linear-gradient(90deg,#f59e0b,#f97316);border-radius:4px;transition:width .3s ease ease-in-out;animation:progressAnimation 1s ease-out}@keyframes progressAnimation{0%{width:0}}.stats-card__circle-progress{position:relative;width:80px;height:80px;margin:0 auto .25rem}@media (max-width: 480px){.stats-card__circle-progress{width:60px;height:60px}}.stats-card__circle{width:100%;height:100%;transform:rotate(-90deg)}.stats-card__circle text{font-size:1rem;font-weight:700;fill:#1f2937;text-anchor:middle;dominant-baseline:middle}.stats-card__circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.stats-card__circle-value{font-size:1.25rem;font-weight:700;color:#1f2937}@media (max-width: 480px){.stats-card__circle-value{font-size:1rem}}.stats-display__reminder{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:.5rem;padding:1rem;display:flex;align-items:center;gap:.5rem;text-align:center}@media (max-width: 480px){.stats-display__reminder{flex-direction:column}}.stats-display__reminder-icon{color:#f59e0b;flex-shrink:0}.stats-display__reminder-icon svg{width:20px;height:20px}.stats-display__reminder-text{color:#6b7280;font-size:.875rem;margin:0;flex:1;font-style:italic}.quote-display{width:100%;padding:1.5rem;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;position:relative;overflow:hidden}.quote-display:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.1"><circle cx="30" cy="30" r="1"/></g></g></svg>');opacity:.3}@media (max-width: 768px){.quote-display{flex-direction:column;text-align:center}}.quote-display__content{position:relative;z-index:1;flex:1}.quote-display__quote{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}@media (max-width: 768px){.quote-display__quote{flex-direction:column;align-items:center}}.quote-display__quote-icon{flex-shrink:0;color:#fffc;margin-top:2px}@media (max-width: 768px){.quote-display__quote-icon{margin-bottom:.5rem}}.quote-display__text{font-size:1.125rem;font-style:italic;line-height:1.6;margin:0;color:#fffffff2}@media (max-width: 768px){.quote-display__text{font-size:1rem}}@media (max-width: 480px){.quote-display__text{font-size:.875rem}}.quote-display__author{font-size:.9rem;color:#fffc;margin:0;text-align:right;font-weight:500}@media (max-width: 768px){.quote-display__author{text-align:center;font-size:.875rem}}.quote-display__refresh{position:relative;z-index:1;width:40px;height:40px;border-radius:50%;background-color:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.quote-display__refresh:hover{background-color:#ffffff4d;transform:rotate(180deg);box-shadow:0 4px 12px #00000026}.quote-display__refresh:active{transform:rotate(180deg) scale(.95)}.quote-display__refresh svg{width:18px;height:18px}.milestone-manager{width:100%;padding:1.5rem;background-color:#fff;border-radius:1rem;box-shadow:0 1px 2px #0000000d;margin-bottom:2rem}.milestone-manager--empty{text-align:center;color:#6b7280;font-style:italic;padding:2rem}.milestone-manager__title{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem;text-align:center}.milestone-manager__form{background-color:#f9fafb;padding:1.5rem;border-radius:.5rem;margin-bottom:2rem;box-shadow:0 1px 2px #0000000d}.milestone-manager__form-group{margin-bottom:1.5rem}.milestone-manager__form-group--half{flex:1;min-width:200px}@media (max-width: 480px){.milestone-manager__form-group--half{width:100%}}.milestone-manager__form-row{display:flex;gap:1.5rem;flex-wrap:wrap}@media (max-width: 480px){.milestone-manager__form-row{flex-direction:column}}.milestone-manager__label{display:block;font-size:.875rem;font-weight:500;color:#1f2937;margin-bottom:.25rem}.milestone-manager__input-with-unit{position:relative;display:flex;align-items:center}.milestone-manager__input{width:100%;padding:.5rem;border:1px solid #e5e7eb;border-radius:.25rem;font-size:1rem;transition:all .15s ease}.milestone-manager__input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.milestone-manager__input[type=number]{padding-right:40px}.milestone-manager__unit{position:absolute;right:.5rem;color:#9ca3af;font-size:.875rem;pointer-events:none}.milestone-manager__textarea{width:100%;padding:.5rem;border:1px solid #e5e7eb;border-radius:.25rem;font-size:1rem;resize:vertical;min-height:80px;transition:all .15s ease}.milestone-manager__textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.milestone-manager__select{width:100%;padding:.5rem;border:1px solid #e5e7eb;border-radius:.25rem;font-size:1rem;background-color:#fff;cursor:pointer;transition:all .15s ease}.milestone-manager__select:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.milestone-manager__helper-text{font-size:.875rem;color:#9ca3af;margin-top:.25rem;font-style:italic}.milestone-manager__form-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}.milestone-manager__button{padding:.5rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s ease}.milestone-manager__button--primary{background-color:#f59e0b;color:#fff}.milestone-manager__button--primary:hover{background-color:#d97706;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.milestone-manager__button--secondary{background-color:#fff;color:#1f2937;border:1px solid #e5e7eb}.milestone-manager__button--secondary:hover{background-color:#f9fafb;border-color:#f59e0b;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.milestone-manager__list-section{margin-top:2rem}.milestone-manager__list-title{font-size:1.25rem;color:#1f2937;margin-bottom:1.5rem;text-align:center}.milestone-manager__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}@media (max-width: 768px){.milestone-manager__list{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 480px){.milestone-manager__list{grid-template-columns:1fr}}.milestone-item{background-color:#f9fafb;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;transition:all .15s ease}.milestone-item:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.milestone-item__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}@media (max-width: 480px){.milestone-item__header{flex-direction:column;gap:.5rem}}.milestone-item__meta{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.milestone-item__category-badge{display:inline-block;padding:2px 8px;border-radius:.25rem;font-size:.75rem;font-weight:500;color:#fff}.milestone-item__week{font-size:.875rem;color:#6b7280;font-weight:500}.milestone-item__date{font-size:.875rem;color:#9ca3af;font-style:italic}.milestone-item__actions{display:flex;gap:.25rem;flex-shrink:0}.milestone-item__action-button{width:32px;height:32px;border:none;border-radius:.25rem;background-color:transparent;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.milestone-item__action-button:hover{background-color:#fff;transform:translateY(-1px)}.milestone-item__action-button:hover--edit{color:#f59e0b}.milestone-item__action-button:hover--delete{color:#ef4444}.milestone-item__action-button svg{width:16px;height:16px}.milestone-item__description{font-size:1rem;color:#1f2937;margin-bottom:.25rem;line-height:1.5}.milestone-item__date-range{font-size:.875rem;color:#9ca3af;font-style:italic;margin:0}.app{min-height:100vh;background-color:#fff;color:#1f2937;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:0;margin:0}.app__content{max-width:1200px;margin:0 auto;padding:0 1.5rem}.app__export{display:flex;justify-content:center;padding:1.5rem;margin-bottom:2rem}.app__export-button{background-color:#3b82f6;color:#fff;border:none;border-radius:.5rem;padding:.5rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s ease}.app__export-button:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.app__export-button:active{transform:translateY(0)}@media (max-width: 768px){.app{padding:0}.app__content{padding:0 1rem}}@media (max-width: 480px){.app__content{padding:0 .5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1f2937;background-color:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:1rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin-bottom:1rem}button{cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:1rem;transition:all .15s ease}button:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}input,textarea,select{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:.25rem;outline:none;transition:all .15s ease}input:focus,textarea:focus,select:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.container{max-width:1200px;margin:0 auto;padding:0 1rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f9fafb}::-webkit-scrollbar-thumb{background:#f59e0b;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#d97706}@media (max-width: 768px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media (max-width: 480px){h1{font-size:1.75rem}h2{font-size:1.25rem}h3{font-size:1.125rem}}
