*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #FBF7F0;--cream-dark: #F3EDE0;--ink: #2D2926;--ink-light: #5C5550;--ink-faint: #9B918A;--sage: #6B9E8A;--sage-light: #A8C8B8;--sage-pale: #EAF4EF;--amber: #C47B50;--dust: #B8A89A;--border: #E5DDD5;--white: #FFFFFF;--font-display: "Cormorant Garamond", "Georgia", serif;--font-body: "Crimson Text", "Georgia", serif;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--shadow-sm: 0 1px 8px rgba(45, 41, 38, .06);--shadow: 0 3px 20px rgba(45, 41, 38, .08);--shadow-lg: 0 8px 40px rgba(45, 41, 38, .12)}html{font-size:18px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--cream);color:var(--ink);font-family:var(--font-body);min-height:100vh;line-height:1.6}.app{min-height:100vh;position:relative;overflow-x:hidden}.grain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideRight{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes drawLine{0%{stroke-dashoffset:var(--dash-total)}to{stroke-dashoffset:0}}@keyframes popIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes barGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.welcome{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;position:relative;overflow:hidden}.welcome-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 70% 50% at 50% 25%,rgba(107,158,138,.1) 0%,transparent 70%),radial-gradient(ellipse 45% 35% at 78% 78%,rgba(196,123,80,.07) 0%,transparent 60%),radial-gradient(ellipse 30% 30% at 15% 70%,rgba(123,143,186,.07) 0%,transparent 60%)}.welcome-ornament{font-family:var(--font-display);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:2.5rem;animation:fadeUp .7s var(--ease-out) both}.welcome-title{font-family:var(--font-display);font-size:clamp(3.2rem,9vw,6rem);font-weight:300;line-height:1;letter-spacing:-.025em;color:var(--ink);margin-bottom:.4rem;animation:fadeUp .7s .08s var(--ease-out) both}.welcome-title em{font-style:italic;color:var(--sage)}.welcome-tagline{font-family:var(--font-display);font-size:clamp(1rem,2.5vw,1.25rem);font-weight:300;font-style:italic;color:var(--ink-faint);margin-bottom:3rem;animation:fadeUp .7s .16s var(--ease-out) both}.welcome-rule{width:1px;height:48px;background:linear-gradient(to bottom,transparent,var(--dust),transparent);margin:0 auto 2.5rem;animation:fadeIn .7s .24s ease both}.welcome-body{max-width:400px;font-size:1.05rem;line-height:1.75;color:var(--ink-light);margin-bottom:3rem;animation:fadeUp .7s .3s var(--ease-out) both}.welcome-sections{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:3rem;animation:fadeUp .7s .36s var(--ease-out) both}.welcome-section-pill{font-family:var(--font-display);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);padding:.35rem .9rem;border:1px solid var(--border);background:transparent}.welcome-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:fadeUp .7s .42s var(--ease-out) both}.btn-primary{display:inline-flex;align-items:center;gap:.7rem;background:var(--ink);color:var(--cream);font-family:var(--font-display);font-size:1.05rem;font-weight:500;letter-spacing:.04em;padding:.9rem 2.6rem;border:none;cursor:pointer;transition:background .2s ease,transform .2s ease,box-shadow .2s ease;position:relative}.btn-primary:hover{background:#3d3732;transform:translateY(-1px);box-shadow:0 6px 24px #2d29262e}.btn-primary:active{transform:translateY(0)}.btn-primary .btn-arrow{display:inline-block;transition:transform .2s ease}.btn-primary:hover .btn-arrow{transform:translate(4px)}.btn-ghost{background:transparent;border:none;color:var(--ink-faint);font-family:var(--font-body);font-size:.95rem;cursor:pointer;padding:.4rem .8rem;transition:color .2s ease;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border)}.btn-ghost:hover{color:var(--ink);text-decoration-color:var(--dust)}.btn-secondary{background:transparent;border:1.5px solid var(--border);color:var(--ink-light);font-family:var(--font-display);font-size:.95rem;letter-spacing:.03em;padding:.75rem 2rem;cursor:pointer;transition:border-color .2s ease,color .2s ease,transform .2s ease;width:100%}.btn-secondary:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-1px)}.welcome-footer{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);font-size:.72rem;letter-spacing:.08em;color:var(--ink-faint);white-space:nowrap;animation:fadeIn 1s .6s ease both}.question-screen{min-height:100vh;display:flex;flex-direction:column}.progress-track{position:fixed;top:0;left:0;right:0;height:3px;background:var(--border);z-index:100}.progress-fill{height:100%;background:linear-gradient(90deg,var(--sage) 0%,var(--sage-light) 100%);transition:width .5s var(--ease-out)}.question-topbar{position:fixed;top:3px;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.9rem 2rem;background:#fbf7f0eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:99}.topbar-section{font-family:var(--font-display);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);transition:color .4s ease}.topbar-counter{font-family:var(--font-body);font-size:.85rem;color:var(--ink-faint)}.question-area{flex:1;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 3rem}.question-inner{width:100%;max-width:580px}.question-card{animation:slideRight .38s var(--ease-out) both}.question-eyebrow{font-family:var(--font-display);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:1.4rem}.question-text{font-family:var(--font-display);font-size:clamp(1.7rem,4.5vw,2.5rem);font-weight:400;line-height:1.2;letter-spacing:-.01em;color:var(--ink);margin-bottom:2.8rem}.answer-options{display:flex;flex-direction:column;gap:.55rem}.answer-btn{display:flex;align-items:center;gap:1.4rem;background:var(--white);border:1.5px solid var(--border);padding:1rem 1.4rem;cursor:pointer;transition:border-color .18s ease,transform .18s ease,background .18s ease;text-align:left;width:100%;position:relative;overflow:hidden;animation:fadeUp .3s var(--ease-out) both}.answer-btn:nth-child(1){animation-delay:.05s}.answer-btn:nth-child(2){animation-delay:.09s}.answer-btn:nth-child(3){animation-delay:.13s}.answer-btn:nth-child(4){animation-delay:.17s}.answer-btn:nth-child(5){animation-delay:.21s}.answer-btn:active{background:var(--sage-pale);border-color:var(--sage)}.answer-btn:focus{outline:none}.answer-btn:focus-visible{outline:2px solid var(--sage);outline-offset:-2px}@media (hover: hover){.answer-btn:hover{border-color:var(--sage);background:var(--sage-pale);transform:translate(4px)}.answer-btn:hover .answer-value{color:var(--sage)}.answer-btn:hover .answer-label-text{color:var(--ink)}}.answer-value{font-family:var(--font-display);font-size:1.15rem;font-weight:500;color:var(--dust);min-width:1.6rem;text-align:center;transition:color .18s ease;flex-shrink:0}.answer-sep{width:1px;height:1.4rem;background:var(--border);flex-shrink:0}.answer-label-text{font-family:var(--font-body);font-size:1rem;color:var(--ink-light);transition:color .18s ease}.section-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d292673;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;padding:2rem;animation:fadeIn .28s ease both}.section-card{background:var(--cream);padding:3rem 3.5rem;max-width:460px;width:100%;text-align:center;animation:scaleUp .35s var(--ease-spring) both;box-shadow:var(--shadow-lg);position:relative}.section-card-num{font-family:var(--font-display);font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:1rem}.section-card-accent{width:36px;height:2.5px;margin:0 auto 1.6rem;border-radius:2px;transition:background .4s ease}.section-card-title{font-family:var(--font-display);font-size:clamp(2rem,5.5vw,2.8rem);font-weight:400;color:var(--ink);line-height:1.1;margin-bottom:.7rem}.section-card-subtitle{font-family:var(--font-body);font-size:1.05rem;font-style:italic;color:var(--ink-faint);line-height:1.6;margin-bottom:2.2rem}.btn-continue{background:var(--ink);color:var(--cream);border:none;padding:.85rem 2.4rem;font-family:var(--font-display);font-size:1rem;font-weight:500;letter-spacing:.05em;cursor:pointer;transition:background .2s ease,transform .2s ease}.btn-continue:hover{background:#3d3732;transform:translateY(-1px)}.results-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:4rem 2rem 3rem;animation:fadeUp .5s var(--ease-out) both}.results-eyebrow{font-family:var(--font-display);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-faint);text-align:center;margin-bottom:2.5rem}.score-ring-wrap{position:relative;width:168px;height:168px;margin:0 auto 1.5rem}.score-ring-wrap svg{transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:var(--border);stroke-width:6}.score-ring-fill{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1.2s var(--ease-out)}.score-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-big{font-family:var(--font-display);font-size:3.6rem;font-weight:300;line-height:1;color:var(--ink)}.score-of{font-family:var(--font-display);font-size:.85rem;color:var(--ink-faint);margin-top:.15rem}.score-badge{display:inline-block;font-family:var(--font-display);font-size:1.3rem;font-weight:500;letter-spacing:.02em;padding:.4rem 1.4rem;text-align:center;margin-bottom:.7rem;animation:popIn .4s .3s var(--ease-spring) both}.score-desc{font-family:var(--font-body);font-size:1rem;font-style:italic;color:var(--ink-faint);max-width:340px;text-align:center;line-height:1.65;margin-bottom:3rem}.breakdown{width:100%;max-width:500px;margin-bottom:2.5rem}.breakdown-heading{font-family:var(--font-display);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);text-align:center;margin-bottom:1.5rem}.breakdown-row{display:flex;align-items:center;gap:.9rem;margin-bottom:.9rem}.breakdown-name{font-family:var(--font-body);font-size:.88rem;color:var(--ink-light);width:155px;flex-shrink:0;text-align:right}.breakdown-track{flex:1;height:5px;background:var(--border);border-radius:3px;overflow:hidden}.breakdown-bar{height:100%;border-radius:3px;transform-origin:left;animation:barGrow .8s var(--ease-out) both}.breakdown-val{font-family:var(--font-display);font-size:.88rem;color:var(--ink-faint);min-width:2.2rem;text-align:right}.results-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:300px}.history-screen{min-height:100vh;max-width:740px;margin:0 auto;padding:3.5rem 2rem;animation:fadeUp .45s var(--ease-out) both}.history-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:.4rem;flex-wrap:wrap;gap:.5rem}.history-title{font-family:var(--font-display);font-size:clamp(2rem,6vw,2.8rem);font-weight:400;color:var(--ink);letter-spacing:-.01em;line-height:1}.history-count-badge{font-family:var(--font-body);font-size:.88rem;color:var(--ink-faint);padding-bottom:.2rem}.history-subtitle{font-family:var(--font-body);font-size:1rem;color:var(--ink-faint);font-style:italic;margin-bottom:2.5rem}.chart-wrap{background:var(--white);border:1px solid var(--border);padding:1.5rem 1.5rem 1rem;margin-bottom:2.5rem;box-shadow:var(--shadow-sm)}.chart-heading{font-family:var(--font-display);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:1rem}.chart-empty{text-align:center;padding:3rem 1rem;font-style:italic;color:var(--ink-faint)}.history-list-heading{font-family:var(--font-display);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:1rem}.history-empty{text-align:center;padding:3rem 2rem;font-style:italic;color:var(--ink-faint);font-size:1.05rem}.history-list{display:flex;flex-direction:column;gap:.65rem;margin-bottom:2.5rem}.history-item{display:flex;align-items:center;gap:1.2rem;padding:1.1rem 1.5rem;background:var(--white);border:1px solid var(--border);border-left-width:3px;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm);animation:fadeUp .3s var(--ease-out) both}.history-item:hover{transform:translate(3px);box-shadow:var(--shadow)}.history-item-score{font-family:var(--font-display);font-size:2.1rem;font-weight:300;line-height:1;min-width:3.2rem;text-align:right}.history-item-info{flex:1;min-width:0}.history-item-label{font-family:var(--font-display);font-size:1rem;font-weight:500;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-item-date{font-family:var(--font-body);font-size:.85rem;color:var(--ink-faint)}.history-item-delete{background:none;border:none;color:var(--dust);cursor:pointer;padding:.5rem;font-size:1rem;opacity:0;transition:opacity .2s ease,color .2s ease;flex-shrink:0}.history-item:hover .history-item-delete{opacity:1}.history-item-delete:hover{color:#b84040}.history-nav{display:flex;flex-wrap:wrap;gap:.75rem}@media (max-width: 600px){.section-card{padding:2rem 1.8rem}.breakdown-name{width:110px;font-size:.8rem}.history-item-delete{opacity:1}.history-item{padding:.9rem 1.1rem;gap:.9rem}.score-ring-wrap{width:140px;height:140px}.score-big{font-size:2.8rem}}
