:root{--color-bg: #FFF8F2;--color-surface: #ffffff;--color-surface-alt: #FFF1E6;--color-text: #3D2B1F;--color-text-secondary: #6B5244;--color-text-muted: #A08979;--color-primary: #C49672;--color-primary-dark: #A87B58;--color-primary-light: #F5E6D8;--color-primary-lighter: #FDF3EB;--color-secondary: #9D8164;--color-accent: #D4A574;--color-accent-light: #FAEADB;--color-accent-warm: #E8B98D;--color-danger: #C97056;--color-danger-light: #FCEAE4;--color-border: #E8D8CA;--color-border-light: #F0E4D8;--shadow-sm: 0 2px 8px rgba(157, 129, 100, .08);--shadow-md: 0 6px 20px rgba(157, 129, 100, .12);--shadow-lg: 0 12px 36px rgba(157, 129, 100, .16);--shadow-glow: 0 4px 24px rgba(196, 150, 114, .2);--radius-sm: 14px;--radius-md: 20px;--radius-lg: 24px;--radius-xl: 32px;--radius-pill: 50px;--font-sans: "Gowun Dodum", "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Jua", "Gowun Dodum", sans-serif;--max-width: 960px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.65;min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%}.navbar{position:sticky;top:0;z-index:100;background:#fff8f2d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);box-shadow:0 1px 12px #9d81640f}.navbar-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px;height:var(--header-height);display:flex;align-items:center;justify-content:space-between}.navbar-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.15rem;color:var(--color-primary);transition:opacity .2s}.navbar-brand:hover{opacity:.8}.navbar-logo{font-size:1.3rem}.navbar-links{display:flex;gap:6px;background:var(--color-primary-lighter);padding:4px;border-radius:var(--radius-pill)}.navbar-links a{padding:8px 20px;border-radius:var(--radius-pill);font-size:.9rem;font-weight:500;color:var(--color-text-secondary);transition:all .25s ease}.navbar-links a:hover{background:#c496721f;color:var(--color-primary-dark)}.navbar-links a.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #c496724d}.main-content{max-width:var(--max-width);margin:0 auto;padding:28px 24px 100px}.page{position:relative;z-index:1;animation:fadeIn .35s ease}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-header h1{font-family:var(--font-display);font-size:1.85rem;font-weight:700;color:var(--color-text);line-height:1.3}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:16px;text-align:center;color:var(--color-text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 24px;border-radius:var(--radius-pill);font-size:.92rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;border:none;transition:all .25s ease;text-decoration:none;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-accent-warm));color:#fff;box-shadow:0 3px 12px #c4967240}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary));box-shadow:0 6px 20px #c4967259;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #c4967233}.btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1.5px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-lighter);border-color:var(--color-primary);color:var(--color-primary-dark);transform:translateY(-1px)}.btn-danger{background:var(--color-danger-light);color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff;transform:translateY(-1px)}.btn-full{width:100%;padding:15px 24px;font-size:1rem}.spinner{width:40px;height:40px;border:3px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.error-text{color:var(--color-danger);font-weight:500}.empty-state{text-align:center;padding:72px 24px;color:var(--color-text-secondary)}.empty-icon{font-size:3.5rem;margin-bottom:16px;color:var(--color-text-muted);opacity:.6}.empty-state p{margin-bottom:24px;font-size:1.08rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.card-grid-spacer{height:50px;grid-column:1 / -1}.card-reveal{opacity:0;transform:translateY(32px);transition:opacity .5s ease,transform .5s ease}.card-reveal.card-visible{opacity:1;transform:translateY(0)}.profile-card-deco{position:absolute;top:5px;right:5px;width:34px;height:auto;object-fit:contain;opacity:1;pointer-events:none;transition:all .3s ease;transform:rotate(15deg)}.profile-card:hover .profile-card-deco{opacity:1;transform:rotate(0) scale(1.1)}.profile-card{background:var(--color-surface);border-radius:var(--radius-md);padding:10px 24px 24px;cursor:pointer;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;position:relative;overflow:visible}.profile-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--color-accent-warm)}.profile-card-header{display:flex;justify-content:flex-end;margin-bottom:8px}.profile-gender-badge{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-size:.8rem;font-weight:700;background:var(--color-primary-light);color:var(--color-primary-dark)}.profile-card-name{font-size:1.18rem;font-weight:700;margin-bottom:6px;color:var(--color-text)}.profile-card-date{font-size:.92rem;color:var(--color-text-secondary);margin-bottom:4px}.profile-card-created{font-size:.8rem;color:var(--color-text-muted)}.form-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:36px;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-md);max-width:560px;margin:0 auto}.form-error{background:var(--color-danger-light);color:var(--color-danger);padding:12px 18px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.9rem;font-weight:500}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.form-group input[type=text],.form-group input[type=date],.form-group input[type=time],.form-group select{width:100%;padding:13px 18px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;font-family:var(--font-sans);background:var(--color-primary-lighter);color:var(--color-text);transition:all .25s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 4px #c4967226}.form-group input:disabled,.form-group select:disabled{opacity:.5;cursor:not-allowed}.radio-group{display:flex;gap:12px}.radio-label{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:13px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.95rem;font-weight:500;transition:all .25s ease;background:var(--color-primary-lighter)}.radio-label input[type=radio]{display:none}.radio-label.selected{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary-dark);font-weight:600;box-shadow:0 2px 8px #c4967226}.time-input-group{display:flex;align-items:center;gap:16px}.time-input-group .checkbox-label{flex-shrink:0;margin-left:auto}.time-input-group input[type=time]{flex:1}.checkbox-label{display:inline-flex;flex-direction:row;align-items:center;gap:12px;cursor:pointer;font-size:.9rem;line-height:20px;white-space:nowrap;color:var(--color-text-secondary)}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);border-radius:6px;-webkit-appearance:none;appearance:none;border:1.5px solid var(--color-border);background:var(--color-primary-lighter);cursor:pointer;position:relative;flex-shrink:0;margin:0 5px 0 0;transition:all .2s ease}.checkbox-label input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.checkbox-label input[type=checkbox]:checked:after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700}.birth-date-inputs{display:flex;align-items:center;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-primary-lighter);overflow:hidden;transition:all .25s ease}.birth-date-inputs:focus-within{border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 4px #c4967226}.birth-date-inputs input,.birth-date-inputs input[type=text]{flex:1;min-width:0;padding:13px 8px;border:none!important;border-radius:0!important;box-shadow:none!important;font-size:1rem;font-family:var(--font-sans);background:transparent!important;color:var(--color-text);text-align:center;outline:none}.birth-date-inputs input:first-child{flex:1.5}.birth-date-inputs input::placeholder{color:var(--color-text-muted)}.birth-time-inputs{display:flex;align-items:center;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-primary-lighter);overflow:hidden;flex:1;transition:all .25s ease}.birth-time-inputs:focus-within{border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 4px #c4967226}.birth-time-inputs input,.birth-time-inputs input[type=text]{flex:1;min-width:0;padding:13px 8px;border:none!important;border-radius:0!important;box-shadow:none!important;font-size:1rem;font-family:var(--font-sans);background:transparent!important;color:var(--color-text);text-align:center;outline:none}.birth-time-inputs input:disabled{opacity:.5}.birth-time-inputs input::placeholder{color:var(--color-text-secondary)}.birth-time-colon{font-size:1.1rem;font-weight:600;color:var(--color-text-muted);flex-shrink:0}.detail-info{background:var(--color-surface);border-radius:var(--radius-md);padding:24px;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);margin-bottom:32px}.info-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-border-light)}.info-row:last-child{border-bottom:none}.info-label{width:120px;font-size:.9rem;font-weight:600;color:var(--color-text-muted);flex-shrink:0}.info-value{font-size:.97rem;color:var(--color-text);font-weight:500}.detail-section{margin-bottom:36px}.detail-section h2{font-family:var(--font-display);font-size:1.35rem;font-weight:700;margin-bottom:18px;color:var(--color-text);padding-bottom:8px;border-bottom:3px solid var(--color-primary);display:inline-block}.pillars-table{background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);position:relative}.pillars-row{display:grid;grid-template-columns:repeat(4,1fr)}.pillars-header .pillar-cell{background:linear-gradient(135deg,var(--color-primary),var(--color-accent-warm));color:#fff;font-weight:600;font-size:.88rem;padding:12px;text-align:center}.pillars-stem .pillar-cell{background:var(--color-primary-lighter)}.pillars-branch .pillar-cell{background:var(--color-surface)}.pillar-cell{padding:18px 8px;text-align:center;border-right:1px solid var(--color-border-light)}.pillar-cell:last-child{border-right:none}.pillar-hanja{display:flex;flex-direction:column;align-items:center;gap:4px}.pillar-hanja .hanja{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--color-text)}.pillar-hanja .hangul{font-size:.82rem;color:var(--color-text-muted)}.pillars-row-labels{position:absolute;right:-48px;top:0;display:none}.five-elements{background:var(--color-surface);border-radius:var(--radius-md);padding:28px;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.element-bar-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}.element-bar-row:last-child{margin-bottom:0}.element-label{width:68px;font-size:.92rem;font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.element-bar-track{flex:1;height:28px;background:var(--color-surface-alt);border-radius:14px;overflow:hidden}.element-bar-fill{height:100%;border-radius:14px;transition:width .7s cubic-bezier(.25,.46,.45,.94);min-width:6px}.element-value{width:34px;text-align:right;font-size:.92rem;font-weight:700;color:var(--color-text)}.yongsin-box{background:linear-gradient(135deg,var(--color-accent-light),var(--color-primary-lighter));border-radius:var(--radius-md);padding:22px 26px;border:1.5px solid var(--color-accent-warm);font-size:1.05rem;font-weight:500;color:var(--color-text)}.interp-card{background:var(--color-surface);border-radius:var(--radius-md);border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);margin-bottom:12px;transition:box-shadow .3s ease,border-color .3s ease;overflow:hidden}.interp-accordion{cursor:pointer;-webkit-user-select:none;user-select:none}.interp-accordion:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.interp-accordion.open{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.interp-accordion-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;gap:12px}.interp-accordion-header h3{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--color-primary-dark);margin:0;flex:1}.interp-accordion.open .interp-accordion-header h3{color:var(--color-primary)}.interp-accordion-arrow{font-size:1.1rem;color:var(--color-text-muted);transition:transform .3s ease;flex-shrink:0}.interp-accordion.open .interp-accordion-arrow{color:var(--color-primary)}.interp-accordion-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}.interp-accordion.open .interp-accordion-body{grid-template-rows:1fr}.interp-accordion-inner{overflow:hidden}.interp-accordion-inner p{padding:16px 22px 20px;margin:0;font-size:.97rem;line-height:1.75;color:var(--color-text-secondary);white-space:pre-line;border-top:1px solid var(--color-border-light)}.spinner-inline{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:8px}.analysis-toast-stack{position:fixed;top:64px;left:50%;transform:translate(-50%);width:min(calc(100% - 24px),440px);z-index:900;display:flex;flex-direction:column;gap:10px;pointer-events:none}.analysis-toast{pointer-events:auto;display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-surface);border:1.5px solid var(--color-primary-lighter);border-radius:14px;box-shadow:0 8px 24px #3521121f;animation:analysis-toast-in .35s ease-out}@keyframes analysis-toast-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.analysis-toast-icon{font-size:1.6rem;flex-shrink:0}.analysis-toast-body{flex:1;min-width:0}.analysis-toast-title{margin:0;font-size:.92rem;font-weight:700;color:var(--color-text)}.analysis-toast-cta{flex-shrink:0;padding:7px 14px;border:none;border-radius:999px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent-warm));color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;box-shadow:0 2px 8px #c496724d;transition:transform .15s ease}.analysis-toast-cta:hover{transform:translateY(-1px)}.analysis-toast-close{flex-shrink:0;width:26px;height:26px;border:none;background:transparent;font-size:1.3rem;line-height:1;color:var(--color-text-muted);cursor:pointer;border-radius:50%}.analysis-toast-close:hover{background:var(--color-primary-lighter);color:var(--color-primary-dark)}.followup-section{margin-top:36px}.followup-input-area .btn:disabled,.followup-input-area .btn-primary:disabled{opacity:1}.followup-input-area h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-primary-dark);margin-bottom:4px}.followup-hint{font-size:.85rem;color:var(--color-text-muted);margin-bottom:14px}.followup-rejected{margin-bottom:18px;padding-bottom:16px;border-bottom:1px dashed var(--color-border-light)}.followup-retry-hint{font-size:.85rem;color:var(--color-primary);font-weight:600;margin-top:12px;text-align:center}.followup-form{position:relative;margin-bottom:12px}.followup-input{width:100%;padding:14px 60px 14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);transition:border-color .2s;box-sizing:border-box}.followup-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #c4967226}.followup-input::placeholder{color:var(--color-text-muted)}.followup-count{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:.78rem;color:var(--color-text-muted)}.followup-result{display:flex;flex-direction:column;gap:14px}.followup-q,.followup-a{display:flex;gap:12px;align-items:flex-start}.followup-q p,.followup-a p{margin:0;font-size:.95rem;line-height:1.7;color:var(--color-text-secondary);flex:1;white-space:pre-line}.followup-q p{font-weight:600;color:var(--color-text)}.followup-badge{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:var(--color-primary);color:#fff;margin-top:1px}.followup-badge-a{background:var(--color-secondary)}.confirm-overlay{position:fixed;inset:0;background:#3d2b1f73;display:flex;align-items:center;justify-content:center;z-index:999;padding:24px;animation:confirmFadeIn .2s ease}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirmSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:32px 28px 24px;max-width:320px;width:100%;text-align:center;box-shadow:0 16px 48px #3d2b1f40;animation:confirmSlideUp .25s ease}.confirm-icon{margin-bottom:12px}.confirm-bear{width:64px;height:64px;object-fit:contain}.confirm-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.confirm-message{font-size:.9rem;line-height:1.6;color:var(--color-text-secondary);margin-bottom:24px}.confirm-actions{display:flex;gap:10px}.confirm-btn-cancel{flex:1;padding:12px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-family:var(--font-display);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.confirm-btn-cancel:hover{background:var(--color-surface-alt)}.confirm-btn-confirm{flex:1;padding:12px;border-radius:var(--radius-md);border:none;background:var(--color-danger);color:#fff;font-family:var(--font-display);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.confirm-btn-confirm:hover{background:#b85e44}.interp-loading{display:flex;flex-direction:column;align-items:center;padding:52px 24px;gap:16px;color:var(--color-text-muted)}.lucky-card{background:linear-gradient(135deg,var(--color-accent-light),var(--color-primary-lighter));border-color:var(--color-accent-warm)}.lucky-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.lucky-item{text-align:center;background:#ffffff80;padding:14px 8px;border-radius:var(--radius-sm)}.lucky-label{display:block;font-size:.8rem;color:var(--color-text-muted);margin-bottom:6px}.lucky-value{font-size:1.12rem;font-weight:700;color:var(--color-text)}.detail-actions{display:flex;gap:12px;margin-top:36px;padding-top:28px;border-top:1.5px solid var(--color-border-light)}.compatibility-selects{display:flex;align-items:center;gap:16px;margin-bottom:28px}.compatibility-selects .form-group{flex:1;margin-bottom:0}.compatibility-vs{padding-bottom:12px;flex-shrink:0}.compatibility-heart{width:72px;height:72px;object-fit:contain;align-self:center}.compat-names{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:36px;flex-wrap:wrap}.compat-name{font-family:var(--font-display);font-size:1.55rem;font-weight:700;color:var(--color-text)}.compat-and{font-size:1.2rem;color:var(--color-primary);font-weight:700}.score-section{display:flex;justify-content:center;margin-bottom:44px}.score-circle{position:relative;width:170px;height:170px}.score-svg{width:100%;height:100%}.score-ring{transition:stroke-dashoffset 1.2s cubic-bezier(.25,.46,.45,.94)}.score-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}.score-number{font-family:var(--font-display);font-size:2.6rem;font-weight:900;line-height:1}.score-unit{font-size:.92rem;color:var(--color-text-muted);margin-top:4px}.compat-history-card{background:var(--color-surface);border-radius:var(--radius-md);padding:26px;cursor:pointer;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;text-align:center;overflow:hidden;position:relative}.compat-history-card:after{content:"";position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:120px;height:60px;background:radial-gradient(ellipse,var(--color-primary-light) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.compat-history-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--color-accent-warm)}.compat-history-card:hover:after{opacity:1}.compat-history-names{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1.08rem;font-weight:700;color:var(--color-text);margin-bottom:14px}.compat-history-vs{color:var(--color-primary)}.compat-history-score{margin-bottom:10px}.score-badge{display:inline-block;padding:5px 18px;border-radius:var(--radius-pill);color:#fff;font-size:.9rem;font-weight:700}.compat-history-date{font-size:.82rem;color:var(--color-text-muted)}.compat-history-delete{margin-top:10px;font-size:.78rem;padding:4px 14px}.home{min-height:100vh;display:flex;flex-direction:column}.hero{position:relative;padding:88px 24px 72px;text-align:center;background:linear-gradient(160deg,#9d8164,#c49672 35%,#d4a574,#e8b98d 85%,#faeadb);color:#fff;overflow:hidden}.hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 80% 60%,rgba(255,248,242,.1) 0%,transparent 40%),radial-gradient(circle at 50% 80%,rgba(157,129,100,.15) 0%,transparent 45%)}.hero-content{position:relative;max-width:600px;margin:0 auto}.hero-title{font-family:var(--font-display);font-size:3.8rem;font-weight:900;letter-spacing:.1em;margin-bottom:18px;text-shadow:0 3px 20px rgba(61,43,31,.15);line-height:1.2}.hero-subtitle{font-size:1.2rem;opacity:.95;margin-bottom:14px;font-weight:500}.hero-desc{font-size:.97rem;opacity:.8;line-height:1.75}.home-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:var(--max-width);margin:-48px auto 0;padding:0 24px;position:relative;z-index:1;flex:1}.action-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:44px 32px;text-align:center;border:1.5px solid var(--color-border-light);box-shadow:var(--shadow-lg);transition:all .35s ease;display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--color-text);overflow:hidden;position:relative}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--radius-xl) var(--radius-xl) 0 0;opacity:0;transition:opacity .3s ease}.action-card-saju:before{background:linear-gradient(90deg,var(--color-primary),var(--color-accent-warm))}.action-card-gunghap:before{background:linear-gradient(90deg,var(--color-accent),var(--color-primary))}.action-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #9d816433}.action-card:hover:before{opacity:1}.action-icon{font-family:var(--font-display);font-size:2.6rem;font-weight:900;width:76px;height:76px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:22px;transition:transform .3s ease}.action-card:hover .action-icon{transform:scale(1.08)}.action-card-saju .action-icon{background:var(--color-primary-light);color:var(--color-primary-dark)}.action-card-gunghap .action-icon{background:var(--color-accent-light);color:var(--color-secondary)}.action-card h2{font-family:var(--font-display);font-size:1.35rem;font-weight:700;margin-bottom:10px}.action-card p{font-size:.92rem;color:var(--color-text-secondary);margin-bottom:18px;line-height:1.55}.action-arrow{font-size:1.3rem;color:var(--color-primary);transition:transform .25s ease;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-primary-lighter);border-radius:50%}.action-card:hover .action-arrow{transform:translate(4px);background:var(--color-primary-light)}.home-footer{text-align:center;padding:36px 24px;color:var(--color-text-muted);font-size:.85rem}.app-header{position:sticky;top:0;z-index:100;background:#fff8f2e6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);padding:4px 16px;height:58px;display:flex;align-items:center}.app-header-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--color-primary)}.app-header-logo{width:35px;height:35px;object-fit:contain;flex-shrink:0}.hero-full{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:60px 24px}.hero-full .hero-content{display:flex;flex-direction:column;align-items:center}.btn-home-start{margin-top:36px;padding:16px 52px;font-size:1.1rem;font-family:var(--font-display);font-weight:700;background:#fffffff2;color:var(--color-primary-dark);border:none;border-radius:var(--radius-pill);cursor:pointer;box-shadow:0 4px 20px #3d2b1f26;transition:all .3s ease;letter-spacing:.05em}.btn-home-start:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 28px #3d2b1f33;background:#fff}.btn-home-start:active{transform:translateY(0) scale(.98)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;display:flex;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--color-border-light);box-shadow:0 -2px 16px #9d816414;padding:6px 0 env(safe-area-inset-bottom,8px);height:auto}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 6px;background:none;border:none;cursor:pointer;position:relative;font-family:var(--font-sans);transition:all .2s ease;-webkit-tap-highlight-color:transparent}.bottom-nav-icon{font-family:var(--font-display);font-size:1.5rem;line-height:1;color:var(--color-text-muted);transition:all .25s ease}.bottom-nav-label{font-size:.7rem;font-weight:600;color:var(--color-text-muted);transition:color .25s ease}.bottom-nav-tab.active .bottom-nav-icon{color:var(--color-primary);transform:scale(1.1)}.bottom-nav-tab.active .bottom-nav-label{color:var(--color-primary-dark)}.bottom-nav-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--color-primary);border-radius:0 0 3px 3px}.bottom-nav-tab.disabled .bottom-nav-icon,.bottom-nav-tab.disabled .bottom-nav-label{opacity:.4}.bottom-nav-badge{position:absolute;top:4px;right:50%;transform:translate(calc(50% + 14px));font-size:.55rem;font-weight:700;background:var(--color-accent-warm);color:#fff;padding:1px 5px;border-radius:6px;line-height:1.3;letter-spacing:.02em}.bottom-nav-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--color-text);color:#fff;padding:10px 24px;border-radius:var(--radius-pill);font-size:.88rem;font-weight:500;font-family:Gowun Dodum,sans-serif;box-shadow:0 4px 16px #00000026;z-index:999;animation:toastIn .3s ease,toastOut .3s ease 1.2s forwards;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}@media(max-width:640px){.hero-title{font-size:2.6rem}.hero{padding:64px 20px 56px}.home-actions{grid-template-columns:1fr;margin-top:-36px;padding:0 16px}.main-content{padding:20px 16px 100px}.page-header h1{font-size:1.45rem}.card-grid{grid-template-columns:1fr}.form-card{padding:24px 20px;border-radius:var(--radius-lg)}.compatibility-selects{flex-direction:column;align-items:stretch}.compatibility-vs{text-align:center;padding:0}.lucky-grid{grid-template-columns:1fr;gap:12px}.pillars-row .pillar-cell{padding:14px 4px}.pillar-hanja .hanja{font-size:1.35rem}.detail-actions{flex-direction:column}.compat-name{font-size:1.25rem}.app-header{padding:4px 16px;height:58px}.hero-full{min-height:calc(100vh - 60px);padding:48px 20px}}.fortune-date-header{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;margin-bottom:16px;background:var(--color-primary-lighter);border-radius:var(--radius-pill);font-family:var(--font-display);font-size:1rem;color:var(--color-primary-dark)}.fortune-date-icon{font-size:1.2em}.fortune-today-pillars{margin-bottom:20px}.fortune-today-pillars table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.fortune-today-pillars th,.fortune-today-pillars td{padding:10px 12px;text-align:center;font-size:.95rem}.fortune-today-pillars thead th{background:var(--color-primary-light);color:var(--color-primary-dark);font-family:var(--font-display);font-weight:600;font-size:.85rem}.fortune-today-pillars tbody td{color:var(--color-text);font-family:var(--font-display);font-size:1.15rem;border-top:1px solid var(--color-border-light)}.fortune-today-pillars .pillar-label{font-size:.8rem;color:var(--color-text-muted);font-family:var(--font-sans);font-weight:500}.fortune-history-card{position:relative;background:var(--color-surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;overflow:hidden}.fortune-history-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));opacity:0;transition:opacity .2s ease}.fortune-history-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.fortune-history-card:hover:after{opacity:1}.fortune-history-name{font-family:var(--font-display);font-size:1.1rem;color:var(--color-text);margin-bottom:4px}.fortune-history-date{font-size:.85rem;color:var(--color-text-muted)}.fortune-history-delete{position:absolute;top:12px;right:12px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(160deg,#9d8164,#c49672 35%,#d4a574,#e8b98d 85%,#faeadb);overflow:hidden}.login-page .hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 80% 60%,rgba(255,248,242,.1) 0%,transparent 40%),radial-gradient(circle at 50% 80%,rgba(157,129,100,.15) 0%,transparent 45%)}.login-content{position:relative;display:flex;flex-direction:column;align-items:center;max-width:400px;width:100%;padding:0 24px;animation:fadeIn .5s ease}.login-logo{width:180px;height:180px;object-fit:contain;margin-bottom:20px;filter:drop-shadow(0 4px 16px rgba(61,43,31,.15))}.login-title{font-family:var(--font-display);font-size:2.8rem;font-weight:900;color:#fff;text-shadow:0 3px 16px rgba(61,43,31,.15);margin-bottom:8px}.login-subtitle{font-size:1.1rem;color:#ffffffe6;margin-bottom:48px;font-weight:500}.social-login-buttons{display:flex;flex-direction:column;gap:12px;width:100%}.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:48px;border:none;border-radius:var(--radius-pill);font-size:.95rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all .25s ease;box-shadow:0 2px 8px #0000001a}.social-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000026}.social-btn:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.social-btn-kakao{background:#fee500;color:#191919}.social-btn-naver{background:#03c75a;color:#fff}.social-btn-google{background:#fff;color:#191919;border:1px solid #dadce0}.social-btn-apple{background:#000;color:#fff}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1.5px solid var(--color-border-light);border-radius:var(--radius-pill);background:var(--color-surface);cursor:pointer;font-family:var(--font-sans);transition:all .2s ease}.user-menu-trigger:hover{border-color:var(--color-primary);background:var(--color-primary-lighter)}.user-menu-provider{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.72rem;font-weight:700;color:#fff;flex-shrink:0}.user-menu-provider-kakao{background:#fee500;color:#191919}.user-menu-provider-naver{background:#03c75a}.user-menu-provider-google{background:#4285f4}.user-menu-provider-apple{background:#000}.user-menu-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid rgba(0,0,0,.08);background:#f2f2f2}.user-menu-name{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:var(--color-surface);border:1.5px solid var(--color-border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:6px;z-index:150;animation:fadeIn .15s ease}.user-menu-logout{display:block;width:100%;padding:10px 16px;border:none;border-radius:10px;background:none;font-size:.9rem;font-weight:500;font-family:var(--font-sans);color:var(--color-danger);cursor:pointer;text-align:left;transition:background .15s ease}.user-menu-logout:hover{background:var(--color-danger-light)}.my-profile-card{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:20px;padding:24px 0}.my-profile-avatar-wrap{position:relative;width:100px;height:100px;margin:0 auto;cursor:pointer;border-radius:50%;overflow:hidden}.my-profile-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--color-border);display:block}.my-profile-avatar-empty{background:var(--color-surface-alt);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.85rem;border:3px dashed var(--color-border)}.my-profile-avatar-overlay{position:absolute;inset:0;background:#00000073;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;border-radius:50%;opacity:0;transition:opacity .2s}.my-profile-avatar-wrap:hover .my-profile-avatar-overlay{opacity:1}.my-profile-field{display:flex;flex-direction:column;gap:6px}.my-profile-field label{font-size:.85rem;color:var(--color-text-muted);font-weight:500;display:flex;align-items:center;gap:6px}.my-profile-row{display:flex;gap:8px;align-items:center}.my-profile-row .input,.my-profile-row .input-readonly{flex:1}.my-profile-row .input-readonly{display:flex;align-items:center;border-width:1.5px;line-height:1.2}.select-sm{width:90px!important;flex:none!important}.my-profile-row-btn{width:90px;flex:none;padding:10px 14px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--color-primary-lighter);color:var(--color-primary-dark);font-size:.92rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-sans);box-sizing:border-box}.my-profile-row-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.my-profile-row-btn:disabled{opacity:.5;cursor:not-allowed}.badge-readonly{font-size:.7rem;background:var(--color-surface-alt);color:var(--color-text-muted);padding:2px 6px;border-radius:4px}.badge-optional{font-size:.7rem;background:#c496721f;color:var(--color-primary);padding:2px 6px;border-radius:4px}.my-profile-error{color:#d9534f;font-size:.8rem;margin:6px 0 0}.cookie-purchase-error{color:#d9534f;font-size:.85rem;margin:8px 0;text-align:center}.input-readonly{background:var(--color-surface-alt);color:var(--color-text-muted);cursor:default;border:1px solid var(--color-border);border-radius:8px;padding:10px 14px;font-size:.95rem;width:100%;box-sizing:border-box}.input{border:1.5px solid var(--color-border);border-radius:8px;padding:10px 14px;font-size:.95rem;width:100%;box-sizing:border-box;font-family:var(--font-sans);background:var(--color-primary-lighter);color:var(--color-text);transition:all .25s ease}.input:focus{outline:none;border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 4px #c4967226}.gender-toggle{display:flex;gap:8px}.gender-btn{flex:1;padding:10px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.95rem;font-family:var(--font-sans);transition:all .15s}.gender-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.user-menu-item{width:100%;padding:10px 16px;background:none;border:none;border-radius:10px;text-align:left;cursor:pointer;color:var(--color-text);font-size:.9rem;font-family:var(--font-sans);font-weight:500;transition:background .15s}.user-menu-item:hover{background:var(--color-surface-alt)}@media(max-width:640px){.login-logo{width:140px;height:140px}.login-title{font-size:2.2rem}.login-subtitle{margin-bottom:36px}.user-menu-name{display:none}}.tarot-phase-center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:1.5rem}.tarot-phase-title{font-family:var(--font-display);font-size:1.5rem;color:var(--color-text)}.tarot-phase-sub{color:var(--color-text-muted);font-size:.9rem}.tarot-topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:.75rem}.tarot-topic-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;font-family:var(--font-sans)}.tarot-topic-btn:hover{border-color:var(--color-primary);transform:translateY(-2px)}.tarot-topic-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.tarot-topic-emoji{font-size:1.8rem}.tarot-topic-label{font-size:.85rem;font-weight:600}.tarot-spread-enter{animation:spreadSectionIn .4s ease both}@keyframes spreadSectionIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.tarot-spread-stagger{animation:spreadCardIn .35s ease both}@keyframes spreadCardIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tarot-spread-list{display:flex;flex-direction:column;gap:10px;margin-top:.75rem}.tarot-spread-card{display:flex;flex-direction:column;gap:4px;padding:16px 20px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:left;font-family:var(--font-sans)}.tarot-spread-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.tarot-spread-card.active{border-color:var(--color-primary);background:linear-gradient(135deg,#c4967214,#c4967205)}.tarot-spread-card-header{display:flex;justify-content:space-between;align-items:center}.tarot-spread-card-label{font-weight:700;font-size:1rem;color:var(--color-text)}.tarot-spread-card-count{font-size:.8rem;color:var(--color-primary);font-weight:600;background:#c496721f;padding:2px 10px;border-radius:var(--radius-pill)}.tarot-spread-card-desc{font-size:.85rem;color:var(--color-text-muted);margin:0}.tarot-card{width:150px;height:250px;aspect-ratio:3 / 5;perspective:800px;cursor:pointer;transition:transform .3s,opacity .3s;flex-shrink:0}.tarot-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1)}.tarot-card.flipped .tarot-card-inner{transform:rotateY(180deg)}.tarot-card-back,.tarot-card-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.tarot-card-back{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border:2px solid #e94560;box-shadow:0 2px 12px #e9456033}.tarot-card-back-symbol{font-size:2rem;color:#e94560;opacity:.8;text-shadow:0 0 20px rgba(233,69,96,.5)}.tarot-card-face{transform:rotateY(180deg);background:#fff;border:2px solid #ddd;padding:0;gap:2px;overflow:hidden}.tarot-card-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;z-index:1;image-rendering:auto;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}.tarot-card-image.reversed{transform:rotate(180deg) translateZ(0)}.tarot-result-card-image{width:100%;max-width:170px;aspect-ratio:3 / 5;height:auto;object-fit:cover;border-radius:8px;display:block;margin:6px auto;box-shadow:0 3px 10px #0000002e}.tarot-result-card-image.reversed{transform:rotate(180deg)}.tarot-result-card .tarot-result-card-emoji{display:none}.tarot-card-face.major{border-color:#9b59b6;box-shadow:0 2px 12px #9b59b626}.tarot-card-reversed-badge{position:absolute;top:4px;right:6px;font-size:.6rem;color:#e74c3c;font-weight:700;background:#e74c3c1a;padding:1px 4px;border-radius:3px}.tarot-card-number{font-size:.6rem;color:#888;font-weight:600}.tarot-card-emoji{font-size:2.2rem;line-height:1}.tarot-card-name{font-size:.6rem;text-align:center;font-weight:600;color:var(--color-text);line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis}.tarot-shuffle-container{position:relative;height:180px;width:200px;display:flex;align-items:center;justify-content:center}.tarot-shuffling-card{position:absolute;animation:tarotShuffle .6s ease-in-out infinite;animation-delay:calc(var(--i, 0) * .08s)}@keyframes tarotShuffle{0%{transform:translate(0) rotate(0)}25%{transform:translate(25px) rotate(8deg)}50%{transform:translate(-15px) rotate(-4deg)}75%{transform:translate(8px) rotate(2deg)}to{transform:translate(0) rotate(0)}}.tarot-fan{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:1rem auto;padding:0 12px;max-width:480px}.tarot-fan .tarot-card{position:relative;transform:translateZ(0);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .4s;width:calc((100% - 50px) / 6);height:auto;aspect-ratio:3 / 5}.tarot-fan .tarot-card:hover{transform:translateY(-8px) scale(1.05);z-index:10}.tarot-fan .tarot-card.selected{transform:scale(.9);opacity:.4;pointer-events:none}.tarot-fan .tarot-card.fade-out{opacity:0;pointer-events:none;transition:opacity .5s}.tarot-drawing-header{text-align:center;margin-bottom:.5rem}.tarot-drawing-header h2{font-family:var(--font-display);font-size:1.3rem;margin-bottom:4px}.tarot-drawing-header p{color:var(--color-primary);font-weight:600;font-size:.95rem}.tarot-drawing-hint{text-align:center;color:var(--color-text-muted);font-size:.85rem;margin-top:.5rem}.tarot-positions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin:1.5rem 0}.tarot-position-slot{text-align:center}.tarot-position-label{font-size:.75rem;color:var(--color-primary-dark);margin-top:8px;font-weight:600}.tarot-reveal-card{cursor:default}.tarot-result-cards{display:flex;justify-content:center;flex-wrap:wrap;gap:16px;max-width:640px;margin:1rem auto 1.5rem}.tarot-result-card{text-align:center;flex:0 0 calc(33.333% - 11px);max-width:200px;padding:12px 8px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);box-sizing:border-box}.tarot-result-card-position{font-size:.65rem;color:#9b59b6;font-weight:700;margin-bottom:4px}.tarot-result-card-emoji{font-size:1.8rem;line-height:1}.tarot-result-card-name{font-size:.7rem;font-weight:600;margin-top:4px;color:var(--color-text)}.tarot-result-card-direction{font-size:.6rem;color:#888;margin-top:2px}@media(max-width:480px){.tarot-card{width:120px;height:200px}.tarot-card-emoji{font-size:1.6rem}.tarot-card-name{font-size:.5rem}.tarot-topic-grid{grid-template-columns:repeat(2,1fr)}.tarot-fan{gap:8px;padding:0 8px}.tarot-result-cards{gap:10px;max-width:100%}.tarot-result-card{flex:0 0 calc(33.333% - 7px);padding:8px 4px}.tarot-result-card-image{max-width:100%;aspect-ratio:3 / 5;height:auto}.tarot-result-card-emoji{font-size:1.4rem}.tarot-positions{gap:8px}}.share-btn{position:fixed;bottom:80px;right:16px;width:48px;height:48px;border-radius:50%;background:#c49672;color:#fff;border:none;font-size:.75rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #00000026;z-index:100;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}.share-btn:active{transform:scale(.9);background:#a87b5a}.shared-view .shared-header{display:flex;justify-content:center;padding:.75rem 1rem}.shared-view .shared-header .app-header-brand{text-decoration:none}.shared-footer{text-align:center;padding:2rem 0 1rem}.shared-footer .btn{display:inline-block}.header-cookie-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1.5px solid var(--color-border-light);border-radius:var(--radius-pill);background:var(--color-surface);cursor:pointer;margin-left:auto;margin-right:6px;transition:all .2s ease;font-family:var(--font-sans)}.header-cookie-btn:hover{border-color:var(--color-accent-warm);background:var(--color-accent-light);transform:translateY(-1px)}.header-cookie-btn:active{transform:translateY(0)}.header-cookie-img{width:22px;height:22px;object-fit:contain}.header-cookie-count{font-size:.85rem;font-weight:700;color:var(--color-text);min-width:16px;text-align:center}.cookie-purchase-modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:28px 24px 24px;max-width:380px;width:100%;box-shadow:0 16px 48px #3d2b1f40;animation:confirmSlideUp .25s ease}.welcome-modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:32px 26px 24px;max-width:400px;width:100%;box-shadow:0 20px 60px #3d2b1f4d;animation:confirmSlideUp .35s ease}.welcome-modal-header{display:flex;flex-direction:column;align-items:center;margin-bottom:16px}.welcome-modal-logo{width:56px;height:56px;object-fit:contain;margin-bottom:10px}.welcome-modal-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--color-primary-dark);margin:0;letter-spacing:-.3px}.welcome-modal-greeting{text-align:center;font-size:1rem;color:var(--color-text-secondary);margin:0 0 18px;line-height:1.5}.welcome-modal-greeting strong{color:var(--color-primary);font-weight:700}.welcome-modal-gift{display:flex;align-items:center;gap:14px;padding:16px 18px;background:linear-gradient(135deg,var(--color-primary-lighter),#fff5e6);border:1.5px dashed var(--color-primary);border-radius:14px;margin-bottom:16px}.welcome-modal-cookie{width:50px;height:50px;object-fit:contain;flex-shrink:0;animation:welcome-cookie-bounce 1.4s ease-in-out infinite}@keyframes welcome-cookie-bounce{0%,to{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-4px) rotate(4deg)}}.welcome-modal-gift-text{display:flex;flex-direction:column;gap:2px}.welcome-modal-gift-label{font-size:.78rem;color:var(--color-text-muted);font-weight:600}.welcome-modal-gift-amount{font-size:1.1rem;font-weight:800;color:var(--color-primary-dark)}.welcome-modal-notes{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:6px}.welcome-modal-notes li{position:relative;padding-left:18px;font-size:.86rem;color:var(--color-text-secondary);line-height:1.5}.welcome-modal-notes li:before{content:"•";position:absolute;left:6px;color:var(--color-primary);font-weight:700}.cookie-purchase-header{text-align:center;margin-bottom:20px}.cookie-purchase-icon{width:56px;height:56px;object-fit:contain;margin-bottom:8px}.cookie-purchase-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--color-text);margin:0 0 6px}.cookie-purchase-current{font-size:.88rem;color:var(--color-text-secondary);margin:0}.cookie-purchase-current strong{color:var(--color-primary);font-weight:700}.cookie-purchase-packages{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.cookie-package-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 10px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:all .2s ease;font-family:var(--font-sans)}.cookie-package-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.cookie-package-card.selected{border-color:var(--color-primary);background:var(--color-primary-lighter);box-shadow:0 2px 12px #c4967233}.cookie-package-card.popular{border-color:var(--color-accent-warm)}.cookie-package-badge{position:absolute;top:-8px;right:-4px;background:var(--color-accent-warm);color:#fff;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-pill)}.cookie-package-label{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.cookie-package-amount{display:flex;align-items:center;gap:4px;font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--color-text)}.cookie-package-img{width:20px;height:20px;object-fit:contain}.cookie-package-price{font-size:.9rem;font-weight:600;color:var(--color-primary-dark)}.cookie-purchase-actions{display:flex;gap:10px}.cookie-btn-buy{background:linear-gradient(135deg,var(--color-primary),var(--color-accent-warm))!important;color:#fff!important}.cookie-btn-buy:disabled{opacity:.5;cursor:not-allowed}.cookie-btn-buy:not(:disabled):hover{box-shadow:0 4px 16px #c4967259}.section-desc{font-size:.85rem;color:#999;margin:-.25rem 0 .75rem;line-height:1.5}.gyeokguk-box{background:linear-gradient(135deg,#faf6f1,#f0e8de);border:2px solid var(--color-primary);border-radius:16px;padding:20px;text-align:center}.gyeokguk-name{font-size:1.4rem;font-weight:700;color:var(--color-primary-dark);margin-bottom:8px}.gyeokguk-desc{font-size:.95rem;color:#6b5b4f;margin-bottom:8px}.gyeokguk-detail{font-size:.85rem;color:#9d8164}.sinsal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:640px){.sinsal-grid{grid-template-columns:1fr}}.sinsal-badge{border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:4px}.sinsal-present{background:linear-gradient(135deg,#fff3e6,#ffe8d6);border:1.5px solid var(--color-primary)}.sinsal-absent{background:#f5f0eb;border:1.5px solid #DDD5CC;opacity:.6}.sinsal-name{font-weight:700;font-size:1rem;color:var(--color-primary-dark)}.sinsal-branch{font-size:.85rem;color:#9d8164}.sinsal-location{font-size:.8rem;color:var(--color-primary);font-weight:600}.sinsal-desc{font-size:.8rem;color:#8b7b6b;margin-top:2px}.gongmang-box{background:#f5f0eb;border:1.5px dashed #C49672;border-radius:12px;padding:16px;text-align:center}.gongmang-branches{display:flex;justify-content:center;gap:16px;margin-bottom:8px}.gongmang-branch{background:#fff;border:1.5px solid var(--color-primary);border-radius:10px;padding:8px 16px;font-weight:600;font-size:1rem;color:var(--color-primary-dark)}.gongmang-desc{font-size:.82rem;color:#9d8164;margin:0}.daeun-info{display:flex;justify-content:space-between;margin-bottom:12px;font-size:.9rem;color:#6b5b4f}.daeun-timeline{display:flex;overflow-x:auto;gap:8px;padding:8px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.daeun-timeline::-webkit-scrollbar{height:4px}.daeun-timeline::-webkit-scrollbar-thumb{background:#d4c4b0;border-radius:4px}.daeun-item{flex:0 0 auto;min-width:80px;background:#faf6f1;border:1.5px solid #DDD5CC;border-radius:12px;padding:12px 10px;text-align:center;transition:all .2s}.daeun-current{background:linear-gradient(135deg,#fff3e6,#ffe8d6);border-color:var(--color-primary);box-shadow:0 2px 12px #c4967240;transform:scale(1.05);margin:0 14px}.daeun-age{font-size:.72rem;color:#9d8164;margin-bottom:4px}.daeun-pillar{display:flex;flex-direction:column;align-items:center;gap:2px}.daeun-hanja{font-size:1.15rem;font-weight:700;color:var(--color-primary-dark)}.daeun-hangul{font-size:.8rem;color:#6b5b4f}.daeun-element{font-size:.75rem;color:#9d8164;margin-top:4px}.daeun-napeum{font-size:.7rem;color:#b8a99a;margin-top:2px}.daeun-napeum-desc{font-size:.65rem;color:#c4b5a5;margin-top:2px;line-height:1.4}.napeum-desc{font-size:.85rem;color:#999;margin-top:.25rem;line-height:1.5}.seun-box{background:linear-gradient(135deg,#faf6f1,#f0e8de);border:2px solid var(--color-primary);border-radius:16px;padding:20px;display:flex;align-items:center;justify-content:center;gap:20px}.seun-pillar{display:flex;flex-direction:column;align-items:center;gap:4px}.seun-hanja{font-size:1.6rem;font-weight:700;color:var(--color-primary-dark)}.seun-hangul{font-size:1rem;color:#6b5b4f}.seun-detail{display:flex;flex-direction:column;gap:4px;font-size:.9rem;color:#9d8164}.daily-cookie-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#fff8e1,#fff3cd);border:1.5px solid #ffe082;border-radius:2rem;padding:.6rem 1.2rem;box-shadow:0 4px 20px #0000001f;z-index:9999;animation:toastSlideIn .4s ease-out;font-size:.95rem;font-weight:600;color:#5d4037}.daily-cookie-toast.toast-exit{animation:toastSlideOut .4s ease-in forwards}.daily-cookie-toast-icon{width:28px;height:28px;animation:cookieBounce .6s ease-out}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}@keyframes cookieBounce{0%{transform:scale(.3) rotate(-30deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.sub-scores{display:flex;flex-direction:column;gap:.75rem}.sub-score-row{display:flex;align-items:center;gap:.5rem}.sub-score-header{min-width:5.5rem;display:flex;flex-direction:column}.sub-score-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.sub-score-weight{font-size:.7rem;color:var(--color-text-muted)}.sub-score-bar-track{flex:1;height:10px;background:var(--color-border-light);border-radius:5px;overflow:hidden}.sub-score-bar-fill{height:100%;border-radius:5px;transition:width .8s ease-out}.sub-score-value{min-width:2.5rem;text-align:right;font-size:.85rem;font-weight:600;color:var(--color-text-secondary)}.fortune-compare{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.fortune-person{background:var(--color-surface-alt);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;gap:.75rem}.fortune-person-name{font-weight:700;font-size:.95rem;color:var(--color-primary-dark);text-align:center;padding-bottom:.5rem;border-bottom:1px solid var(--color-border-light)}.fortune-block{display:flex;flex-direction:column;align-items:center;gap:.25rem}.fortune-block-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);letter-spacing:.05em}.fortune-block-pillar{display:flex;flex-direction:column;align-items:center}.fortune-hanja{font-size:1.3rem;font-weight:700;color:var(--color-text)}.fortune-hangul{font-size:.8rem;color:var(--color-text-secondary)}.fortune-block-detail{font-size:.75rem;color:var(--color-text-secondary)}.fortune-block-napeum{font-size:.7rem;color:var(--color-text-muted);margin-top:.15rem}@media(max-width:400px){.fortune-compare{grid-template-columns:1fr}}.day-master-box{display:flex;flex-direction:column;gap:0;border-radius:var(--radius-md);overflow:hidden}.day-master-columns{display:grid;grid-template-columns:1fr 1fr;gap:0}.day-master-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem .75rem;background:var(--color-surface-alt)}.day-master-card:first-child{border-right:1px solid var(--color-border-light)}.day-master-stem{font-size:2rem;font-weight:700;color:var(--color-text)}.day-master-element{font-size:.78rem;color:var(--color-text-muted)}.day-master-bottom{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.25rem;background:var(--color-primary-lighter);border-top:1px solid var(--color-border-light)}.day-master-relation-badge{display:inline-block;padding:.35rem 1rem;border-radius:var(--radius-pill);background:var(--color-primary-light);color:var(--color-primary-dark);font-size:.9rem;font-weight:600}.day-master-desc{font-size:.82rem;color:var(--color-text-secondary);text-align:center;margin:0;line-height:1.6}.branch-interactions{display:flex;flex-wrap:wrap;gap:.5rem}.branch-tag{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.82rem}.branch-harmony{background:#a8c08e2e;color:#6b8f4e}.branch-clash{background:#c9705626;color:#c97056}.branch-tag-icon{font-weight:700;font-size:.9rem}.branch-tag-text{font-size:.8rem}.branch-harmony-hint{font-size:.78rem;color:var(--color-text-muted);margin-top:.25rem}.complement-box{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--color-surface-alt);border-radius:var(--radius-md)}.complement-badge{font-size:.9rem;font-weight:600;color:var(--color-primary-dark)}.complement-bonus{font-size:.8rem;color:var(--color-text-muted)}.day-master-name{font-size:.82rem;font-weight:600;color:var(--color-primary-dark);margin-bottom:.25rem}.day-master-nature{font-size:.72rem;color:var(--color-text-muted);text-align:center;max-width:140px;line-height:1.45;margin-top:.2rem}.branch-tag-card{display:flex;flex-direction:column;gap:.3rem;padding:.75rem 1rem;border-radius:var(--radius-sm);flex:1 1 calc(50% - .25rem);min-width:150px}.branch-harmony-card{background:#a8c08e26;border:1px solid rgba(168,192,142,.3)}.branch-clash-card{background:#c970561f;border:1px solid rgba(201,112,86,.25)}.branch-tag-top{display:flex;align-items:center;gap:.5rem}.branch-tag-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.branch-tag-meaning{font-size:.72rem;color:var(--color-text-muted);line-height:1.4}.branch-tag-detail{font-size:.75rem;color:var(--color-text-secondary);line-height:1.4}.combined-elements{display:flex;flex-direction:column;gap:.6rem}.combined-el-row{display:flex;align-items:center;gap:.75rem}.combined-el-header{display:flex;flex-direction:column;min-width:80px}.combined-el-label{font-size:.82rem;font-weight:600;color:var(--color-text)}.combined-el-nature{font-size:.68rem;color:var(--color-text-muted)}.combined-el-value{font-size:.82rem;font-weight:600;color:var(--color-text-secondary);min-width:20px;text-align:right}.combined-el-row .element-bar-track{flex:1}.complement-summary{margin-top:.75rem;padding:.75rem 1rem;background:var(--color-surface-alt);border-radius:var(--radius-sm);text-align:center}.complement-balance{font-size:.85rem;font-weight:600;color:var(--color-text);margin:0}.complement-detail{font-size:.78rem;color:var(--color-primary-dark);margin:.35rem 0 0}
