*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg-void:#faf6ed;
  --bg:#f7f2e8;
  --surface:#f0ead8;
  --card:#ffffff;
  --card-hover:#f5f8f0;
  --gold:#b8860b;
  --gold-bright:#d4a020;
  --gold-dim:#8b6914;
  --gold-glow:rgba(184,134,11,.06);
  --gold-glow-s:rgba(184,134,11,.14);
  --text:#3d3226;
  --text2:#6b5d4d;
  --text3:#9e8e78;
  --danger:#c0392b;
  --success:#27ae60;
  --mystical:#8b5a8c;
  --info:#2980b9;
  --border:#d9d0c0;
  --shadow:rgba(61,50,38,.1);
  --font-t:'Ma Shan Zheng',cursive;
  --font-h:'Noto Serif SC',serif;
  --font-b:'Noto Serif SC',serif;
  --font-m:'JetBrains Mono',monospace;
}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--font-b);color:var(--text);line-height:1.8;
  background:var(--bg-void);
  min-height:100vh;overflow-x:hidden;
}
canvas#particles{position:fixed;inset:0;z-index:0;pointer-events:none}
.screen{display:none;position:relative;z-index:1;min-height:100vh}
.screen.active{display:flex}
button{font-family:var(--font-b);cursor:pointer;border:none;background:none;color:inherit;outline:none;outline:1px solid transparent}
button:focus{box-shadow:0 0 0 2px rgba(184,134,11,.25);border-radius:6px}
button:focus-visible{box-shadow:0 0 0 2px rgba(184,134,11,.35);border-radius:6px}
button:disabled{cursor:not-allowed;opacity:.45}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(184,134,11,.25);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(184,134,11,.4)}

/* START SCREEN */
#screen-start{flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;background:linear-gradient(180deg,#faf6ed 0%,#f7f2e8 100%)}
.start-sigil{font-size:4.5rem;margin-bottom:1rem;opacity:.8;color:#8b4513;animation:sigilPulse 4s ease infinite}
.start-title{font-family:var(--font-t);font-size:clamp(2.8rem,7.5vw,5.5rem);color:#8b4513;letter-spacing:.12em;text-shadow:2px 2px 4px rgba(139,69,19,.15);animation:titleGlow 3.5s ease infinite alternate}
.start-sub{font-family:var(--font-h);font-size:clamp(.9rem,2.3vw,1.25rem);color:#6b4423;margin-top:.6rem;letter-spacing:.22em}
.start-desc{max-width:560px;color:#8b6914;font-size:.92rem;margin:2.2rem auto;line-height:2}
.start-choices{display:flex;gap:1.25rem;margin-top:1.8rem;flex-wrap:wrap;justify-content:center}
.start-btn{padding:1.1rem 2.6rem;border:2px solid #8b6914;border-radius:12px;font-size:1.02rem;letter-spacing:.06em;min-width:235px;background:#fffaf0;color:#6b4423;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:2px 2px 8px var(--shadow)}
.start-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(184,134,11,.08),transparent);transform:translateX(-100%);transition:transform .6s ease}
.start-btn:hover{border-color:#8b4513;color:#8b4513;box-shadow:4px 4px 12px rgba(139,69,19,.2),inset 0 0 18px rgba(184,134,11,.08);transform:translateY(-2px)}
.start-btn:hover::before{transform:translateX(100%)}
.start-btn:active{transform:translateY(1px);box-shadow:2px 2px 6px rgba(139,69,19,.15)}
.start-btn b{display:block;font-size:1.1rem;margin-bottom:.3rem;color:#8b4513}
.start-btn small{color:#9e8e78;font-size:.78rem}
.start-save{margin-top:1.25rem}
.start-save button{padding:.7rem 1.5rem;border:1px solid var(--border);border-radius:10px;color:#6b5d4d;font-size:.85rem;transition:all .25s ease;background:#fff}
.start-save button:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.start-save button:active{transform:translateY(1px)}

/* CREATE SCREEN */
#screen-create{flex-direction:column;padding:1.75rem;min-height:100vh;background:linear-gradient(180deg,#f7f2e8 0%,#faf6ed 100%)}
.create-top{text-align:center;padding:1.2rem 0 1.5rem}
.create-top h2{font-family:var(--font-t);font-size:1.85rem;color:#8b4513;letter-spacing:.08em}
.create-top p{color:var(--text3);font-size:.85rem;margin-top:.35rem}
.create-step{display:none;flex:1;flex-direction:column;align-items:center;justify-content:center;padding:1rem 0;animation:fadeUp .45s ease}
.create-step.active{display:flex}
.step-label{font-family:var(--font-h);font-size:1.1rem;color:#6b5d4d;margin-bottom:1.4rem;padding-bottom:.6rem;border-bottom:2px solid #d9d0c0;letter-spacing:.08em}
.option-grid{display:grid;gap:1rem;width:100%;max-width:950px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.option-card{background:#fff;border:1px solid #d9d0c0;border-radius:14px;padding:1.3rem;cursor:pointer;transition:all .28s ease;position:relative;overflow:hidden;box-shadow:2px 2px 8px var(--shadow)}
.option-card::after{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:#8b4513;opacity:0;transition:opacity .28s ease}
.option-card:hover{background:#fffaf0;border-color:#8b6914;transform:translateY(-3px);box-shadow:4px 4px 16px rgba(139,69,19,.15)}
.option-card.selected{border-color:#8b4513;background:#fffaf0;box-shadow:4px 4px 16px rgba(139,69,19,.2),0 0 16px rgba(184,134,11,.1)}
.option-card.selected::after{opacity:1}
.option-card h3{font-family:var(--font-h);font-size:1rem;margin-bottom:.35rem;color:#3d3226}
.option-card .opt-icon{font-size:1.75rem;margin-bottom:.55rem;display:block}
.option-card p{color:#9e8e78;font-size:.84rem;line-height:1.6}
.tier-card .tier-level{display:inline-block;padding:.18rem .65rem;border-radius:4px;font-size:.72rem;font-family:var(--font-m);margin-bottom:.55rem}
.tier-1 .tier-level{background:rgba(139,69,19,.12);color:#8b4513}
.tier-2 .tier-level{background:rgba(100,100,100,.1);color:#6b5d4d}
.tier-3 .tier-level{background:rgba(70,130,180,.1);color:#2980b9}
.tier-4 .tier-level{background:rgba(46,139,87,.1);color:#27ae60}
.tier-5 .tier-level{background:rgba(184,134,11,.12);color:#8b4513}
.tier-6 .tier-level{background:rgba(139,92,217,.12);color:#8b5a8c}

/* ATTRIBUTES */
.attr-panel{width:100%;max-width:620px}
.attr-row{display:flex;align-items:center;gap:.9rem;padding:.8rem 0;border-bottom:1px solid #d9d0c0}
.attr-label{width:2.4rem;height:2.4rem;display:flex;align-items:center;justify-content:center;font-size:.85rem;border:1px solid #8b6914;color:#8b4513;border-radius:6px;flex-shrink:0;font-family:var(--font-h);background:#fffaf0}
.attr-name{width:3.2rem;font-size:.88rem;color:#6b5d4d;flex-shrink:0}
.attr-ctrl{display:flex;align-items:center;gap:.45rem}
.attr-ctrl button{width:2.2rem;height:2.2rem;border:1px solid #d9d0c0;border-radius:6px;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .22s ease;color:#6b5d4d;background:#fff}
.attr-ctrl button:hover:not(:disabled){border-color:#8b6914;color:#8b4513;background:#fffaf0}
.attr-ctrl button:active:not(:disabled){transform:scale(.96)}
.attr-ctrl button:disabled{opacity:.3;cursor:not-allowed}
.attr-val{width:2.4rem;text-align:center;font-family:var(--font-m);font-size:1.05rem;font-weight:700;color:#8b4513}
.attr-bar-wrap{flex:1;height:6px;background:#f0ead8;border-radius:4px;overflow:hidden}
.attr-bar{height:100%;border-radius:4px;transition:width .45s ease,background .45s ease}
.attr-bar.low{background:linear-gradient(90deg,#c0392b,#e74c3c)}
.attr-bar.mid{background:linear-gradient(90deg,#b8860b,#d4a020)}
.attr-bar.high{background:linear-gradient(90deg,#27ae60,#2ecc71)}
.attr-bar.max{background:linear-gradient(90deg,#8b5a8c,#9b59b6)}
.attr-remain{text-align:center;margin-top:1.3rem;padding:1.1rem;background:#fff;border-radius:12px;border:1px solid #d9d0c0;box-shadow:2px 2px 8px var(--shadow)}
.attr-remain span{font-family:var(--font-m);font-size:1.85rem;font-weight:700;color:#8b4513}
.attr-remain small{display:block;color:#9e8e78;font-size:.82rem;margin-top:.35rem}

.era-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.7rem;width:100%;max-width:620px}
.era-btn{padding:.8rem;border:1px solid #d9d0c0;border-radius:10px;background:#fff;text-align:center;font-size:.9rem;transition:all .25s ease;color:#3d3226}
.era-btn:hover{border-color:#8b6914;background:#fffaf0}
.era-btn.selected{border-color:#8b4513;color:#8b4513;background:#fffaf0}

/* TALENT */
.talent-reveal{text-align:center}
.talent-card-wrap{width:220px;height:300px;margin:0 auto 1.5rem;perspective:1000px;cursor:pointer}
.talent-card-inner{position:relative;width:100%;height:100%;transition:transform .75s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.talent-card-wrap.flipped .talent-card-inner{transform:rotateY(180deg)}
.talent-card-front,.talent-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.6rem}
.talent-card-front{background:linear-gradient(135deg,#fff,#f7f2e8);border:2px solid #d9d0c0}
.talent-card-front .q-mark{font-size:3.8rem;color:#8b4513;opacity:.6}
.talent-card-front small{color:#9e8e78;margin-top:.6rem;font-size:.78rem}
.talent-card-back{transform:rotateY(180deg);border:2px solid #8b4513;background:linear-gradient(135deg,#fffaf0,#fff)}
.talent-card-back .t-name{font-family:var(--font-t);font-size:1.45rem;color:#8b4513;margin-bottom:.55rem}
.talent-card-back .t-desc{color:#6b5d4d;font-size:.86rem;text-align:center;line-height:1.65}
.talent-card-back .t-effects{margin-top:.85rem;font-size:.8rem;color:#27ae60}
.talent-card-back.rarity-godlike{border-color:#d4a020;box-shadow:4px 4px 16px rgba(212,160,32,.25)}
.talent-card-back.rarity-rare{border-color:#9b59b6;box-shadow:4px 4px 16px rgba(155,89,182,.2)}
.talent-card-back.rarity-normal{border-color:#2980b9}
.talent-card-back.rarity-negative{border-color:#c0392b;box-shadow:4px 4px 16px rgba(192,57,43,.2)}

.btn-confirm{padding:.9rem 2.7rem;background:linear-gradient(135deg,#8b6914,#b8860b);color:#fff;font-weight:700;border-radius:10px;font-size:1rem;letter-spacing:.06em;transition:all .28s ease;margin-top:1.4rem;box-shadow:2px 2px 8px var(--shadow)}
.btn-confirm:hover{box-shadow:4px 4px 12px rgba(139,69,19,.2);transform:translateY(-2px)}
.btn-confirm:active{transform:translateY(0);box-shadow:2px 2px 6px rgba(139,69,19,.15)}
.btn-confirm:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn-back{padding:.55rem 1.35rem;border:1px solid #d9d0c0;border-radius:10px;color:#6b5d4d;font-size:.84rem;transition:all .25s ease;margin-top:1.1rem;background:#fff}
.btn-back:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.btn-back:active{transform:translateY(1px)}

/* RANDOM */
#screen-random{flex-direction:column;align-items:center;justify-content:center;padding:2.25rem;text-align:center}
.random-title{font-family:var(--font-t);font-size:1.95rem;color:var(--gold);margin-bottom:2rem}
.random-spinning{font-size:1.25rem;color:var(--text2);min-height:2rem;margin-bottom:1rem}
.random-reveal-item{opacity:0;transform:translateY(22px);transition:all .55s ease;margin-bottom:1.6rem;max-width:520px}
.random-reveal-item.show{opacity:1;transform:translateY(0)}
.random-reveal-item h3{color:var(--gold);font-size:1.08rem;margin-bottom:.35rem}
.random-reveal-item p{color:var(--text2);font-size:.9rem}

/* GAME */
#screen-game{flex-direction:column;height:100vh}
.game-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.4rem;background:#fff;border-bottom:1px solid #d9d0c0;flex-shrink:0;box-shadow:0 2px 8px var(--shadow)}
.game-header-left{display:flex;gap:.9rem;align-items:center;flex-wrap:wrap}
.badge{padding:.28rem .75rem;border-radius:5px;font-size:.78rem;font-family:var(--font-m);letter-spacing:.02em}
.badge-world{background:rgba(184,134,11,.1);color:#8b4513;border:1px solid #d9d0c0}
.badge-age{background:#f7f2e8;color:#6b5d4d;border:1px solid #d9d0c0}
.badge-location{background:#f0ead8;color:#9e8e78;font-size:.74rem;border:1px solid #d9d0c0}
.game-header-right{display:flex;gap:.6rem}
.btn-icon{width:2.3rem;height:2.3rem;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fff;border:1px solid #d9d0c0}
.btn-icon:hover{background:#fffaf0;border-color:#8b6914}
.btn-icon:active{background:#f7f2e8}

/* Dropdown Menu */
.dropdown-menu{position:relative}
.dropdown-toggle{font-size:1.2rem;padding:0;width:2.3rem;height:2.3rem}
.dropdown-toggle.active{background:#fffaf0;border-color:#8b6914}
.dropdown-content{position:absolute;right:0;top:calc(100% + .4rem);min-width:140px;background:#fff;border:1px solid #d9d0c0;border-radius:10px;box-shadow:4px 4px 16px rgba(61,50,38,.15);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s ease;z-index:100;padding:.35rem}
.dropdown-content.show{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:block;width:100%;text-align:left;padding:.65rem .85rem;border:none;background:none;color:#3d3226;font-size:.88rem;border-radius:6px;transition:all .2s ease}
.dropdown-item:hover{background:#fffaf0;color:#8b4513}
.dropdown-item.danger{color:#c0392b}
.dropdown-item.danger:hover{background:rgba(192,57,43,.1);color:#c0392b}

.game-body{display:flex;flex:1;overflow:hidden}
.game-sidebar{width:270px;border-right:1px solid #d9d0c0;display:flex;flex-direction:column;flex-shrink:0;background:#fff}
.sidebar-tabs{display:flex;border-bottom:1px solid #d9d0c0}
.sidebar-tabs button{flex:1;padding:.65rem .4rem;font-size:.78rem;color:#9e8e78;border-bottom:2px solid transparent;transition:all .28s ease;background:transparent}
.sidebar-tabs button.active{color:#8b4513;border-bottom-color:#8b4513;background:#fffaf0}
.sidebar-panel{flex:1;overflow-y:auto;padding:1.1rem}
.sidebar-panel.hidden{display:none}
.char-card{text-align:center;margin-bottom:1.25rem;padding:1rem;background:#f7f2e8;border-radius:10px;border:1px solid #d9d0c0}
.char-avatar{width:68px;height:68px;border-radius:50%;margin:0 auto .7rem;background:#fff;border:2px solid #8b6914;display:flex;align-items:center;justify-content:center;font-size:1.85rem}
.char-name{font-family:var(--font-h);font-size:1.02rem;color:#3d3226}
.char-info{font-size:.78rem;color:#9e8e78;margin-top:.25rem}
.stat-item{margin-bottom:.75rem}
.stat-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.stat-label span:first-child{font-size:.8rem;color:#6b5d4d}
.stat-label span:last-child{font-family:var(--font-m);font-size:.8rem;color:#8b4513}
.stat-bar{height:5px;background:#f0ead8;border-radius:3px;overflow:hidden}
.stat-fill{height:100%;border-radius:3px;transition:width .55s ease}
.res-section{margin-top:1.3rem;padding-top:1rem;border-top:1px solid #d9d0c0}
.res-section h4{font-size:.8rem;color:#9e8e78;margin-bottom:.65rem;letter-spacing:.08em}
.res-item{display:flex;justify-content:space-between;font-size:.84rem;margin-bottom:.35rem}
.res-item span:last-child{font-family:var(--font-m);color:#8b4513}
.rel-card{padding:.7rem;margin-bottom:.6rem;background:#fff;border-radius:10px;border-left:3px solid #8b4513;border:1px solid #d9d0c0}
.rel-name{font-size:.88rem;color:#3d3226;display:flex;justify-content:space-between}
.rel-role{font-size:.74rem;color:#9e8e78}
.rel-aff{font-family:var(--font-m);font-size:.76rem}
.log-entry{padding:.55rem 0;border-bottom:1px solid #f0ead8;font-size:.78rem;color:#9e8e78;line-height:1.55}
.game-main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.narrative-area{flex:1;overflow-y:auto;padding:2.2rem 2.6rem;font-size:1rem;line-height:2}
.narrative-area .year-title{font-family:var(--font-t);font-size:1.55rem;color:#8b4513;margin-bottom:1.1rem;letter-spacing:.07em}
.narrative-area .year-subtitle{color:#9e8e78;font-size:.84rem;margin-bottom:1.3rem}
.narrative-area .narrative-text{color:#3d3226;white-space:pre-line}
.narrative-area .narrative-text .highlight{color:#8b4513}
.narrative-area .narrative-text .danger{color:#c0392b}
.narrative-area .narrative-text .success{color:#27ae60}
.narrative-area .narrative-text .mystical{color:#8b5a8c}
.choices-area{padding:1.3rem 2.6rem;border-top:1px solid #d9d0c0;background:#fff;flex-shrink:0}
.choice-btn{display:block;width:100%;text-align:left;padding:1.1rem 1.35rem;margin-bottom:.7rem;border:1px solid #d9d0c0;border-radius:10px;background:#fff;font-size:.92rem;line-height:1.65;transition:opacity .4s ease,transform .4s cubic-bezier(.22,1,.36,1);opacity:0;transform:translateY(20px);box-shadow:2px 2px 6px var(--shadow);will-change:transform,opacity;backface-visibility:hidden;transform-style:preserve-3d}
.choice-btn.visible{opacity:1;transform:translateY(0)}
.choice-btn:hover:not(:disabled){border-color:#8b6914;background:#fffaf0;box-shadow:4px 4px 12px rgba(139,69,19,.15);transform:translateX(5px)}
.choice-btn:active:not(:disabled){transform:translateX(3px);background:#f7f2e8}
.choice-btn .choice-tag{display:inline-block;padding:.14rem .45rem;border-radius:4px;font-family:var(--font-m);font-size:.72rem;margin-right:.55rem;background:rgba(184,134,11,.12);color:#8b4513}
.choice-btn .choice-hint{display:block;font-size:.76rem;color:#9e8e78;margin-top:.35rem}
.advance-btn{display:block;width:100%;padding:.85rem;text-align:center;border:1px solid #8b6914;border-radius:10px;color:#8b4513;font-size:.92rem;letter-spacing:.07em;background:#fffaf0;transition:all .28s ease}
.advance-btn:hover:not(:disabled){background:#fff;box-shadow:4px 4px 12px rgba(139,69,19,.15)}
.advance-btn:active:not(:disabled){transform:translateY(1px);background:#fff}

/* DEATH */
#screen-death{flex-direction:column;align-items:center;justify-content:center;padding:2.2rem;background:linear-gradient(180deg,#faf6ed 0%,#f7f2e8 100%)}
.death-scroll{max-width:680px;width:100%;background:#fff;border:1px solid #d9d0c0;border-radius:18px;padding:2.7rem;animation:scrollUnroll .7s ease .45s both;box-shadow:4px 4px 16px rgba(61,50,38,.15)}
.death-scroll h2{font-family:var(--font-t);font-size:2.1rem;color:#8b4513;text-align:center;margin-bottom:2.1rem;letter-spacing:.14em}
.death-section{margin-bottom:1.6rem}
.death-section h3{font-family:var(--font-h);font-size:1.02rem;color:#8b6914;border-bottom:1px solid #d9d0c0;padding-bottom:.45rem;margin-bottom:.9rem;letter-spacing:.09em}
.death-section p{color:#6b5d4d;font-size:.9rem;line-height:1.85}
.death-stats{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;font-size:.88rem;color:#6b5d4d}
.death-stats dt{color:#9e8e78}
.death-stats dd{color:#3d3226;font-family:var(--font-m);text-align:right}
.death-grade{text-align:center;font-family:var(--font-t);font-size:2.6rem;color:#8b4513;margin:1.6rem 0}
.death-karma{text-align:center;font-size:1.02rem;color:#6b5d4d;margin-bottom:2.1rem}
.death-karma span{font-family:var(--font-m);font-size:1.35rem;color:#8b4513}

/* KARMA */
#screen-karma{flex-direction:column;align-items:center;justify-content:center;padding:2.2rem;background:linear-gradient(180deg,#faf6ed 0%,#f7f2e8 100%)}
.karma-title{font-family:var(--font-t);font-size:2rem;color:#8b4513;margin-bottom:.6rem}
.karma-balance{color:#6b5d4d;margin-bottom:2.1rem;font-size:.98rem}
.karma-balance span{font-family:var(--font-m);color:#8b4513;font-size:1.25rem}
.karma-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.1rem;max-width:850px;width:100%;margin-bottom:2.1rem}
.karma-item{background:#fff;border:1px solid #d9d0c0;border-radius:14px;padding:1.35rem;transition:all .28s ease;box-shadow:2px 2px 8px var(--shadow)}
.karma-item:hover{border-color:#8b6914;box-shadow:4px 4px 12px rgba(139,69,19,.12)}
.karma-item h3{font-size:.98rem;color:#3d3226;margin-bottom:.35rem}
.karma-item p{font-size:.82rem;color:#9e8e78;margin-bottom:.85rem}
.karma-item .karma-cost{font-family:var(--font-m);font-size:.88rem;color:#8b4513}
.karma-item button{margin-top:.55rem;padding:.45rem 1.1rem;border:1px solid #8b6914;border-radius:8px;color:#8b4513;font-size:.82rem;transition:all .25s ease;background:#fffaf0}
.karma-item button:hover:not(:disabled){background:#fff}
.karma-item button:disabled{opacity:.4;cursor:not-allowed}
.karma-item.purchased{opacity:.55;border-color:rgba(39,174,96,.35)}
.karma-item.purchased h3::after{content:' ✓';color:#27ae60}
.btn-next-life{padding:1.05rem 3.2rem;background:linear-gradient(135deg,#8b5a8c,#6b4a6c);color:#fff;font-size:1.12rem;font-weight:700;border-radius:12px;letter-spacing:.09em;transition:all .28s ease;box-shadow:2px 2px 8px var(--shadow)}
.btn-next-life:hover{box-shadow:4px 4px 12px rgba(139,92,172,.2);transform:translateY(-2px)}
.btn-next-life:active{transform:translateY(0);box-shadow:2px 2px 6px rgba(139,92,172,.15)}



@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes sigilPulse{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:.9;transform:scale(1.03)}}
@keyframes titleGlow{0%{text-shadow:0 0 18px rgba(201,168,76,.18),0 0 36px rgba(201,168,76,.06)}100%{text-shadow:0 0 36px rgba(201,168,76,.32),0 0 72px rgba(201,168,76,.12)}}
@keyframes deathFade{0%{background:rgba(0,0,0,1)}100%{background:transparent}}
@keyframes scrollUnroll{from{opacity:0;transform:translateY(45px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}

/* START EXTRAS */
.start-extras{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}
.start-extra-btn{padding:.7rem 1.6rem;border:1px solid #d9d0c0;border-radius:10px;color:#6b5d4d;font-size:.9rem;letter-spacing:.05em;transition:all .28s ease;background:#fff}
.start-extra-btn:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0;box-shadow:2px 2px 8px var(--shadow)}
.start-extra-btn:active{transform:translateY(1px);background:#fff}

/* AUDIO TOGGLE */
#btn-audio{font-size:1.05rem}

/* AUTO SAVE TOGGLE */
#btn-auto-save{font-size:1.05rem}
#btn-auto-save.auto-save-off{
  opacity:0.45;
  background:#f7f2e8;
}
#btn-auto-save.auto-save-off:hover{
  opacity:0.7;
}

/* SHARE BUTTON */
.btn-share{padding:.85rem 2.1rem;border:1px solid #8b6914;border-radius:12px;color:#8b4513;font-size:.98rem;letter-spacing:.05em;background:#fffaf0;transition:all .28s ease;display:block;width:100%;max-width:340px;margin:1.1rem auto 0;box-shadow:2px 2px 6px var(--shadow)}
.btn-share:hover{background:#fff;box-shadow:4px 4px 12px rgba(139,69,19,.15)}
.btn-share:active{transform:translateY(1px)}
.death-actions{text-align:center;display:flex;flex-direction:column;gap:.6rem;align-items:center}

/* ACHIEVEMENT TOAST */
.achievement-toast{position:fixed;top:1.4rem;right:1.4rem;z-index:9999;display:flex;align-items:center;gap:1rem;padding:1.1rem 1.6rem;background:#fff;border:1px solid #8b6914;border-radius:14px;box-shadow:4px 4px 16px rgba(139,69,19,.2);transform:translateX(120%);opacity:0;transition:all .5s cubic-bezier(.4,0,.2,1);max-width:380px}
.achievement-toast.show{transform:translateX(0);opacity:1}
.achievement-toast-icon{font-size:2.6rem;flex-shrink:0}
.achievement-toast-title{font-size:.76rem;color:#8b6914;letter-spacing:.11em;margin-bottom:.22rem}
.achievement-toast-name{font-family:var(--font-h);font-size:1.08rem;color:#3d3226;margin-bottom:.18rem}
.achievement-toast-desc{font-size:.8rem;color:#9e8e78}

/* ACHIEVEMENT PAGE */
.achievement-page{padding:2.2rem;min-height:100vh;animation:fadeIn .45s ease;background:linear-gradient(180deg,#faf6ed 0%,#f7f2e8 100%)}
.achievement-header{text-align:center;margin-bottom:2.1rem;position:relative}
.btn-back-home{position:absolute;left:0;top:0;padding:.55rem 1.15rem;border:1px solid #d9d0c0;border-radius:8px;color:#9e8e78;font-size:.84rem;transition:all .28s ease;background:#fff}
.btn-back-home:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.btn-back-home:active{transform:translateY(1px)}
.achievement-title{font-family:var(--font-t);font-size:2.25rem;color:#8b4513;letter-spacing:.09em}
.achievement-progress{margin-top:1.1rem;color:#6b5d4d;font-size:.92rem}
.ach-progress-num{font-family:var(--font-m);color:#8b4513;font-size:1.15rem;font-weight:700}
.ach-progress-bar{width:220px;height:4px;background:#f0ead8;border-radius:3px;margin:.6rem auto 0;overflow:hidden}
.ach-progress-fill{height:100%;background:linear-gradient(90deg,#8b6914,#b8860b);border-radius:3px;transition:width .55s ease}
.achievement-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.1rem;max-width:950px;margin:0 auto}
.achievement-card{background:#fff;border:1px solid #d9d0c0;border-radius:14px;padding:1.3rem;text-align:center;transition:all .28s ease;box-shadow:2px 2px 8px var(--shadow)}
.achievement-card.unlocked{border-color:#8b6914;background:#fffaf0}
.achievement-card.unlocked:hover{border-color:#8b4513;transform:translateY(-3px);box-shadow:4px 4px 16px rgba(139,69,19,.18)}
.achievement-card.locked{opacity:.48}
.ach-icon{font-size:2.1rem;margin-bottom:.55rem}
.ach-name{font-family:var(--font-h);font-size:.98rem;color:#3d3226;margin-bottom:.35rem}
.ach-desc{font-size:.8rem;color:#9e8e78;line-height:1.5}

/* COLLECTION PAGE */
.collection-page{padding:2.2rem;min-height:100vh;animation:fadeIn .45s ease;background:linear-gradient(180deg,#faf6ed 0%,#f7f2e8 100%)}
.collection-header{text-align:center;margin-bottom:2.1rem;position:relative}
.collection-title{font-family:var(--font-t);font-size:2.25rem;color:#8b4513;letter-spacing:.09em}
.collection-tabs{display:flex;justify-content:center;gap:.6rem;margin-bottom:2.1rem;flex-wrap:wrap}
.coll-tab{padding:.65rem 1.3rem;border:1px solid #d9d0c0;border-radius:10px;color:#9e8e78;font-size:.86rem;transition:all .28s ease;background:#fff}
.coll-tab:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.coll-tab.active{border-color:#8b4513;color:#8b4513;background:#fffaf0}
.collection-content.hidden{display:none}
.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.1rem;max-width:950px;margin:0 auto}
.collection-card{background:#fff;border:1px solid #d9d0c0;border-radius:14px;padding:1.3rem;text-align:center;transition:all .28s ease;box-shadow:2px 2px 8px var(--shadow)}
.collection-card.unlocked{border-color:#8b6914;background:#fffaf0}
.collection-card.unlocked:hover{border-color:#8b4513;transform:translateY(-3px);box-shadow:4px 4px 16px rgba(139,69,19,.18)}
.collection-card.locked{opacity:.48}
.coll-icon{font-size:2.1rem;margin-bottom:.55rem}
.coll-name{font-family:var(--font-h);font-size:.98rem;color:#3d3226;margin-bottom:.35rem}
.coll-desc{font-size:.8rem;color:#9e8e78;line-height:1.55}
.coll-empty{text-align:center;color:#9e8e78;font-size:.92rem;padding:2.2rem}
.talent-rarity-godlike{color:#d4a020}
.talent-rarity-rare{color:#9b59b6}
.talent-rarity-normal{color:#2980b9}
.talent-rarity-negative{color:#c0392b}

/* 属性变化提示样式 */
.attr-change-toast{
  position: fixed;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.8rem 1.4rem;
  background: rgba(255,250,240,0.95);
  border: 1px solid #d9d0c0;
  border-radius: 12px;
  box-shadow: 4px 4px 20px rgba(139,69,19,.2);
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  animation: attrToastIn 0.4s ease forwards, attrToastOut 0.5s ease 1.3s forwards;
}

.attr-change-toast.attr-change-positive{
  border-color: #27ae60;
  box-shadow: 4px 4px 20px rgba(39,174,96,.2);
}

.attr-change-toast.attr-change-negative{
  border-color: #c0392b;
  box-shadow: 4px 4px 20px rgba(192,57,43,.2);
}

.attr-toast-icon{
  font-size: 1.8rem;
  animation: iconBounce 0.6s ease;
}

.attr-toast-content{
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
}

.attr-toast-name{
  font-family: "Noto Serif SC", serif;
  font-size: 1.1rem;
  color: #3d3226;
}

.attr-toast-arrow{
  font-size: 1.2rem;
  font-weight: bold;
}

.attr-change-positive .attr-toast-arrow{
  color: #27ae60;
}

.attr-change-negative .attr-toast-arrow{
  color: #c0392b;
}

.attr-toast-value{
  font-family: "Ma Shan Zheng", cursive;
  font-size: 1.4rem;
  font-weight: bold;
}

.attr-change-positive .attr-toast-value{
  color: #27ae60;
}

.attr-change-negative .attr-toast-value{
  color: #c0392b;
}

@keyframes attrToastIn {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.5);
  }
  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

@keyframes attrToastOut {
  0% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -60%) scale(0.8);
  }
}

@keyframes iconBounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

/* ========================================
   RESPONSIVE DESIGN - PC端优化 (1024px以上)
   ======================================== */
@media (min-width: 1024px) {
  .game-main {
    max-width: 900px;
    margin: 0 auto;
  }
  
  .narrative-area {
    font-size: 1.05rem;
    line-height: 2.1;
  }
  
  .choice-btn {
    padding: 1.2rem 1.5rem;
  }
}

/* ========================================
   RESPONSIVE DESIGN - 平板端 (768px - 1023px)
   ======================================== */
@media (max-width: 1023px) and (min-width: 768px) {
  .game-sidebar {
    width: 240px;
  }
  
  .narrative-area {
    padding: 1.8rem 2rem;
  }
}

/* ========================================
   RESPONSIVE DESIGN - 移动端 (480px - 767px)
   ======================================== */
@media (max-width: 767px) {
  /* 全局字体调整 */
  html {
    font-size: 15px;
  }
  
  /* 开始界面优化 */
  #screen-start {
    padding: 1.5rem 1rem;
  }
  
  .start-sigil {
    font-size: 3.5rem;
  }
  
  .start-title {
    font-size: 2.2rem;
    letter-spacing: .08em;
  }
  
  .start-sub {
    font-size: .85rem;
    letter-spacing: .15em;
  }
  
  .start-desc {
    font-size: .85rem;
    margin: 1.5rem auto;
    padding: 0 .5rem;
  }
  
  .start-choices {
    flex-direction: column;
    width: 100%;
    max-width: 340px;
    gap: 1rem;
  }
  
  .start-btn {
    min-width: 0;
    width: 100%;
    padding: 1rem 1.5rem;
  }
  
  .start-extra-btn {
    flex: 1;
    min-width: 120px;
  }
  
  /* 创建界面优化 */
  #screen-create {
    padding: 1rem;
  }
  
  .create-top h2 {
    font-size: 1.5rem;
  }
  
  .step-label {
    font-size: 1rem;
    margin-bottom: 1rem;
  }
  
  .option-grid {
    grid-template-columns: 1fr;
    gap: .8rem;
  }
  
  .option-card {
    padding: 1rem;
  }
  
  /* 属性面板优化 */
  .attr-panel {
    padding: 0 .5rem;
  }
  
  .attr-row {
    gap: .6rem;
    padding: .6rem 0;
  }
  
  .attr-label {
    width: 2rem;
    height: 2rem;
    font-size: .75rem;
  }
  
  .attr-name {
    width: 2.5rem;
    font-size: .8rem;
  }
  
  .attr-ctrl button {
    width: 2rem;
    height: 2rem;
  }
  
  .era-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: .5rem;
  }
  
  /* 游戏界面优化 */
  .game-header {
    padding: .6rem 1rem;
    flex-wrap: wrap;
    gap: .5rem;
  }
  
  .game-header-left {
    gap: .6rem;
  }
  
  .badge {
    padding: .2rem .5rem;
    font-size: .72rem;
  }
  
  .btn-icon {
    width: 2rem;
    height: 2rem;
  }
  
  .game-sidebar {
    position: fixed;
    left: -280px;
    top: 0;
    bottom: 0;
    width: 280px;
    z-index: 50;
    transition: left .3s ease;
    background: #fff;
    box-shadow: 5px 0 24px rgba(139,69,19,.25);
  }
  
  .game-sidebar.open {
    left: 0;
  }
  
  .sidebar-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .narrative-area {
    padding: 1.4rem 1.2rem;
  }
  
  .narrative-area .year-title {
    font-size: 1.35rem;
  }
  
  .choices-area {
    padding: 1rem 1.2rem;
  }
  
  .choice-btn {
    padding: 1rem 1.2rem;
    margin-bottom: .6rem;
    font-size: .9rem;
  }
  
  .advance-btn {
    padding: .9rem;
  }
  
  /* 死亡界面优化 */
  #screen-death {
    padding: 1.5rem 1rem;
  }
  
  .death-scroll {
    padding: 1.5rem;
    max-width: 100%;
    border-radius: 14px;
  }
  
  .death-scroll h2 {
    font-size: 1.75rem;
  }
  
  .death-grade {
    font-size: 2rem;
  }
  
  /* 功德界面优化 */
  .karma-grid {
    grid-template-columns: 1fr;
    gap: .8rem;
  }
  
  .karma-item {
    padding: 1rem;
  }
  
  /* 成就/图鉴界面优化 */
  .achievement-page,
  .collection-page {
    padding: 1.5rem 1rem;
  }
  
  .achievement-grid,
  .collection-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: .8rem;
  }
  
  .achievement-card,
  .collection-card {
    padding: 1rem;
  }
  
  /* 模态框优化 */
  .modal {
    max-width: 95%;
    padding: 0;
  }
  
  .modal-header {
    padding: 1rem;
  }
  
  .modal-content {
    padding: 1rem;
  }
  
  .save-slots {
    gap: .7rem;
  }
  
  .save-slot {
    padding: .9rem;
    flex-direction: column;
    align-items: flex-start;
  }
  
  .save-actions {
    width: 100%;
    margin-top: .5rem;
  }
  
  .save-btn {
    flex: 1;
    padding: .5rem;
    font-size: .8rem;
  }
  
  /* 分享对话框优化 */
  .share-dialog {
    max-width: 95%;
  }
  
  .share-dialog img {
    border-radius: 10px;
  }
  
  /* 按钮触摸优化 */
  button {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }
  
  .start-btn:active,
  .choice-btn:active,
  .btn-confirm:active,
  .btn-back:active,
  .btn-icon:active {
    transform: scale(0.98);
  }
}

/* ========================================
   RESPONSIVE DESIGN - 小屏手机 (320px - 479px)
   ======================================== */
@media (max-width: 479px) {
  html {
    font-size: 14px;
  }
  
  .start-sigil {
    font-size: 3rem;
  }
  
  .start-title {
    font-size: 1.9rem;
  }
  
  .option-grid {
    grid-template-columns: 1fr;
  }
  
  .era-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .achievement-grid,
  .collection-grid {
    grid-template-columns: 1fr;
  }
  
  .death-stats {
    grid-template-columns: 1fr;
  }
  
  .karma-grid {
    grid-template-columns: 1fr;
  }
  
  .game-header {
    justify-content: space-between;
  }
  
  .game-header-right {
    order: -1;
    width: 100%;
    justify-content: flex-end;
  }
}

/* MODAL & SAVE SYSTEM */
.modal-overlay{position:fixed;inset:0;background:rgba(61,50,38,.5);display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(5px)}
.modal{background:#fff;border:1px solid #d9d0c0;border-radius:18px;box-shadow:4px 4px 20px rgba(61,50,38,.25);max-width:500px;width:94%;overflow:hidden;animation:slideUp .32s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;border-bottom:1px solid #d9d0c0;background:#fffaf0}
.modal-header h3{font-family:var(--font-h);color:#8b4513;font-size:1.12rem}
.modal-close{width:34px;height:34px;border-radius:50%;border:1px solid #d9d0c0;color:#9e8e78;background:transparent;font-size:1.25rem;cursor:pointer;transition:all .25s ease}
.modal-close:hover{border-color:#8b6914;color:#8b4513;background:#fff}
.modal-content{padding:1.3rem}
.save-slots{display:grid;gap:.9rem}
.save-slot{background:#fff;border:1px solid #d9d0c0;border-radius:14px;padding:1.1rem;display:flex;align-items:center;justify-content:space-between;gap:.9rem;transition:all .28s ease}
.save-slot:hover{border-color:#8b6914;background:#fffaf0}
.save-slot.empty{opacity:.6}
.save-info{flex:1}
.save-name{font-family:var(--font-h);color:#3d3226;font-size:1.02rem;margin-bottom:.25rem}
.save-meta{font-size:.78rem;color:#9e8e78;display:flex;gap:.9rem;flex-wrap:wrap}
.save-meta span{display:flex;align-items:center;gap:.3rem}
.save-actions{display:flex;gap:.6rem}
.save-btn{padding:.55rem 1rem;border-radius:10px;border:1px solid #d9d0c0;color:#6b5d4d;background:transparent;font-size:.82rem;cursor:pointer;transition:all .25s ease}
.save-btn:hover{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.save-btn.save{border-color:#8b6914;color:#8b4513;background:#fffaf0}
.save-btn.save:hover{background:#fff}
.save-btn.delete{border-color:#c0392b;color:#c0392b}
.save-btn.delete:hover{background:rgba(192,57,43,.1)}
.choice-btn.disabled-choice{opacity:.45;cursor:not-allowed;background:#f7f2e8;border:1px dashed #d9d0c0;}
.choice-reqs{font-size:.76rem;color:#9e8e78;display:block;margin-top:.45rem;font-family:var(--font-m);}
#life-chart{width:100%;max-width:620px;height:auto;display:block;margin:0 auto;border-radius:12px;background:#f7f2e8;}

/* 致命选择样式 */
.choice-deadly {
  border: 2px solid var(--danger) !important;
  background: linear-gradient(135deg, #fff5f5 0%, #fff 100%) !important;
  box-shadow: 0 0 12px rgba(192, 57, 43, 0.15) !important;
}

.choice-deadly:hover:not(:disabled) {
  background: linear-gradient(135deg, #ffe8e8 0%, #fff5f5 100%) !important;
  box-shadow: 0 0 20px rgba(192, 57, 43, 0.25) !important;
  transform: translateX(5px) scale(1.01);
}

.choice-deadly .choice-tag {
  background: rgba(192, 57, 43, 0.15) !important;
  color: var(--danger) !important;
}

.choice-death-warning {
  display: block;
  font-size: .76rem;
  color: var(--danger);
  margin-top: .45rem;
  font-family: var(--font-m);
  font-weight: 600;
  animation: deathWarningPulse 2s ease-in-out infinite;
}

@keyframes deathWarningPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

/* 冒险选择样式 */
.choice-risky {
  border: 2px solid var(--gold) !important;
  background: linear-gradient(135deg, #fffbf0 0%, #fff 100%) !important;
  box-shadow: 0 0 12px rgba(184, 134, 11, 0.15) !important;
}

.choice-risky:hover:not(:disabled) {
  background: linear-gradient(135deg, #fff5e0 0%, #fffbf0 100%) !important;
  box-shadow: 0 0 20px rgba(184, 134, 11, 0.25) !important;
  transform: translateX(5px) scale(1.01);
}

.choice-risky .choice-tag {
  background: rgba(184, 134, 11, 0.15) !important;
  color: var(--gold) !important;
}

.choice-risk-hint {
  display: block;
  font-size: .76rem;
  color: var(--gold);
  margin-top: .45rem;
  font-family: var(--font-m);
}

/* ANIMATIONS */
@keyframes fadeInAnim {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeOutAnim {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(-10px); }
}
@keyframes slideUpAnim {
  from { opacity: 0; transform: translateY(22px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideDownAnim {
  from { opacity: 0; transform: translateY(-22px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideLeftAnim {
  from { opacity: 0; transform: translateX(22px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes slideRightAnim {
  from { opacity: 0; transform: translateX(-22px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes pulseAnim {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}
@keyframes scaleInAnim {
  from { opacity: 0; transform: scale(0.96); }
  to { opacity: 1; transform: scale(1); }
}
@keyframes shakeAnim {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-5px); }
  75% { transform: translateX(5px); }
}
@keyframes numberPopAnim {
  0% { transform: scale(1); }
  50% { transform: scale(1.3); }
  100% { transform: scale(1); }
}

.screen {
  transition: opacity 0.32s ease, transform 0.32s ease;
}
.screen.fade-in {
  animation: fadeInAnim 0.32s ease forwards;
}
.screen.fade-out {
  animation: fadeOutAnim 0.32s ease forwards;
}
.slide-up {
  animation: slideUpAnim 0.42s ease forwards;
}
.slide-down {
  animation: slideDownAnim 0.42s ease forwards;
}
.slide-left {
  animation: slideLeftAnim 0.32s ease forwards;
}
.slide-right {
  animation: slideRightAnim 0.32s ease forwards;
}
.pulse {
  animation: pulseAnim 2.2s ease-in-out infinite;
}
.scale-in {
  animation: scaleInAnim 0.32s ease forwards;
}
.shake {
  animation: shakeAnim 0.5s ease;
}
.number-pop {
  animation: numberPopAnim 0.32s ease;
}
.attr-change-positive {
  color: var(--success) !important;
  animation: numberPopAnim 0.32s ease;
}
.attr-change-negative {
  color: var(--danger) !important;
  animation: numberPopAnim 0.32s ease;
}
.narrative-text {
  animation: slideUpAnim 0.42s ease;
}
.choice-btn.visible {
  animation: slideLeftAnim 0.32s ease forwards;
}
.advance-btn.visible {
  animation: slideUpAnim 0.32s ease forwards;
}

/* ========================================
   新手引导样式
   ======================================== */
.guide-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  display: none;
}

.guide-overlay.active {
  pointer-events: none;
  display: block;
}

.guide-mask {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transition: clip-path 0.3s ease;
}

.guide-mask.has-hole {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 
    calc(var(--hole-left) - 20px) calc(var(--hole-top) - 20px),
    calc(var(--hole-left) - 20px) calc(var(--hole-bottom) + 20px),
    calc(var(--hole-right) + 20px) calc(var(--hole-bottom) + 20px),
    calc(var(--hole-right) + 20px) calc(var(--hole-top) - 20px),
    calc(var(--hole-left) - 20px) calc(var(--hole-top) - 20px));
}

.guide-highlight {
  position: absolute;
  border: 3px solid var(--gold);
  border-radius: 12px;
  box-shadow: 0 0 0 4px rgba(184, 134, 11, 0.3), 0 8px 32px rgba(0, 0, 0, 0.3);
  transition: all 0.4s ease;
  pointer-events: none;
}

.guide-highlight.pulse {
  animation: guideHighlightPulse 1.5s ease-in-out infinite;
}

@keyframes guideHighlightPulse {
  0%, 100% {
    box-shadow: 0 0 0 4px rgba(184, 134, 11, 0.3), 0 8px 32px rgba(0, 0, 0, 0.3);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(184, 134, 11, 0.5), 0 8px 32px rgba(0, 0, 0, 0.4);
  }
}

.guide-tooltip {
  position: absolute;
  background: linear-gradient(135deg, #fffaf0 0%, #fff 100%);
  border: 2px solid var(--gold);
  border-radius: 16px;
  padding: 1.25rem 1.5rem;
  max-width: 340px;
  min-width: 280px;
  box-shadow: 0 8px 32px rgba(139, 69, 19, 0.25);
  z-index: 9999;
  pointer-events: auto;
  opacity: 0;
  transform: scale(0.9) translateY(10px);
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.guide-tooltip.show {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.guide-tooltip::before {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  background: #fffaf0;
  border: 2px solid var(--gold);
  border-right: none;
  border-top: none;
  transform: rotate(-45deg);
}

.guide-tooltip.position-top::before {
  bottom: -10px;
  left: 50%;
  margin-left: -8px;
  transform: rotate(-45deg);
}

.guide-tooltip.position-bottom::before {
  top: -10px;
  left: 50%;
  margin-left: -8px;
  transform: rotate(135deg);
}

.guide-tooltip.position-left::before {
  right: -10px;
  top: 50%;
  margin-top: -8px;
  transform: rotate(-135deg);
}

.guide-tooltip.position-right::before {
  left: -10px;
  top: 50%;
  margin-top: -8px;
  transform: rotate(45deg);
}

.guide-content {
  margin-bottom: 1rem;
}

.guide-content .guide-icon {
  font-size: 2rem;
  text-align: center;
  margin-bottom: 0.75rem;
}

.guide-content .guide-title {
  font-family: var(--font-h);
  font-size: 1.1rem;
  color: var(--gold);
  margin-bottom: 0.5rem;
  text-align: center;
}

.guide-content .guide-desc {
  font-size: 0.9rem;
  color: var(--text2);
  line-height: 1.7;
}

.guide-content .guide-desc p {
  margin-bottom: 0.5rem;
}

.guide-content .guide-desc p:last-child {
  margin-bottom: 0;
}

.guide-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--border);
}

.guide-btn-skip {
  padding: 0.4rem 0.8rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text3);
  font-size: 0.8rem;
  background: transparent;
  cursor: pointer;
  transition: all 0.25s ease;
}

.guide-btn-skip:hover {
  border-color: var(--gold-dim);
  color: var(--gold-dim);
  background: #fffaf0;
}

.guide-progress {
  flex: 1;
  text-align: center;
  font-size: 0.8rem;
  color: var(--text3);
  font-family: var(--font-m);
}

.guide-btn-next {
  padding: 0.5rem 1.2rem;
  background: linear-gradient(135deg, var(--gold-dim) 0%, var(--gold) 100%);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s ease;
}

.guide-btn-next:hover {
  transform: translateY(-2px);
  box-shadow: 2px 4px 12px rgba(184, 134, 11, 0.35);
}

.guide-btn-next:active {
  transform: translateY(0);
}

/* 引导步骤高亮动画 */
.guide-highlight.goto-top {
  animation: guideGotoTop 0.4s ease forwards;
}

.guide-highlight.goto-bottom {
  animation: guideGotoBottom 0.4s ease forwards;
}

.guide-highlight.goto-left {
  animation: guideGotoLeft 0.4s ease forwards;
}

.guide-highlight.goto-right {
  animation: guideGotoRight 0.4s ease forwards;
}

@keyframes guideGotoTop {
  from { transform: translateY(20px); }
  to { transform: translateY(0); }
}

@keyframes guideGotoBottom {
  from { transform: translateY(-20px); }
  to { transform: translateY(0); }
}

@keyframes guideGotoLeft {
  from { transform: translateX(20px); }
  to { transform: translateX(0); }
}

@keyframes guideGotoRight {
  from { transform: translateX(-20px); }
  to { transform: translateX(0); }
}

/* 移动端引导样式适配 */
@media (max-width: 767px) {
  .guide-tooltip {
    max-width: 90vw;
    min-width: 240px;
    padding: 1rem 1.2rem;
  }

  .guide-content .guide-icon {
    font-size: 1.75rem;
  }

  .guide-content .guide-title {
    font-size: 1rem;
  }

  .guide-content .guide-desc {
    font-size: 0.85rem;
  }
}
