@import "https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=Cinzel:wght@400;600;700&family=Crimson+Text:ital,wght@0,400;0,600;1,400;1,600&family=MedievalSharp&family=IM+Fell+English+SC&family=IM+Fell+English:ital@0;1&display=swap";:root{--bg-deep:#0a0d14;--bg-mid:#0f1420;--bg-card:#131828;--bg-card2:#0e1520;--accent:#7c3aed;--accent2:#a855f7;--accent3:#c084fc;--gold:#d4a853;--gold2:#f0c97a;--red:#dc2626;--red-soft:#ef4444;--blood:#8b0000;--blood2:#b91c1c;--teal:#0d9488;--border:#2a2f4a;--border2:#3d3060;--text:#e2e0f0;--text-dim:#8b85a8;--text-muted:#5a5478;--color-warning:#f87171;--color-safe:var(--teal);--glow-purple:#7c3aed4d;--glow-gold:#d4a85340;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--accent-bg-low:#7c3aed0d;--accent-bg-mid:#7c3aed1a;--accent-bg-high:#7c3aed26;--gold-bg-low:#d4a8530d;--gold-bg-mid:#d4a8531a;--blood-bg-low:#8b000012;--blood-bg-mid:#8b00001f;--blood-bg-high:#8b000026}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-deep);color:var(--text);background-image:radial-gradient(at 20% 10%,#7c3aed12 0%,#0000 50%),radial-gradient(at 80% 90%,#8b000014 0%,#0000 50%);min-height:100vh;padding:20px;font-family:Crimson Text,Georgia,serif}[data-theme=parchemin]{--font-title:"MedievalSharp", "Cinzel Decorative", serif;--font-heading:"IM Fell English SC", "Cinzel", serif;--font-body:"Crimson Text", Georgia, serif;--text:#3b2a1a;--text-dim:#5a4030;--text-muted:#8a6a50;--bg-deep:#e0cca0;--bg-mid:#eddfc0;--bg-card:#f0e4c8;--bg-card2:#e8d8b0;--border:#64461e40;--border2:#64461e66;--gold:#7a5510;--gold2:#9a7020;--gold-bg-low:#7855141a;--gold-bg-mid:#78551433;--blood:#8b1a1a;--blood2:#a02020;--red:#8b1a1a;--red-soft:#8b1a1a1f;--blood-bg-low:#8b1a1a14;--blood-bg-mid:#8b1a1a24;--blood-bg-high:#8b1a1a33;--accent:#5a2d82;--accent2:#7040a0;--accent3:#8a55b8;--accent-bg-low:#5a2d8214;--accent-bg-mid:#5a2d8226;--accent-bg-high:#5a2d8238;--teal:#2a6e60;--color-safe:#2a6e60;--color-warning:#8b1a1a}[data-theme=parchemin] body{font-family:var(--font-body);background:radial-gradient(at 15% 20%,#8b642824 0%,#0000 50%),radial-gradient(at 85% 75%,#7850141f 0%,#0000 45%),radial-gradient(#64461e0f 0%,#0000 60%),radial-gradient(at 70% 10%,#a0783217 0%,#0000 35%),linear-gradient(170deg,#e8d5a8 0%,#f0e2c0 15%,#e5d0a0 35%,#f2e6c8 55%,#dcc89a 80%,#e8d8b0 100%)}[data-theme=parchemin] body:before{content:"";pointer-events:none;z-index:9998;opacity:.07;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='6' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;position:fixed;inset:0}[data-theme=parchemin] body:after{content:"";pointer-events:none;z-index:9999;opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.02 0.06' numOctaves='3' seed='5' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23c)'/%3E%3C/svg%3E");background-repeat:repeat;position:fixed;inset:0}[data-theme=parchemin] .sheet{background:radial-gradient(ellipse at 0% 0%, #8c642824 0%, transparent 35%), radial-gradient(ellipse at 100% 100%, #825a231f 0%, transparent 35%), radial-gradient(ellipse at 50% 50%, #a082460a 0%, transparent 50%), var(--bg-mid);border:none;border-radius:0;position:relative;overflow:visible;box-shadow:3px 6px 18px #50321438,-2px 3px 12px #5032141a,7px 1px 22px #50321414,inset 0 0 80px #7855280f,inset 25px 0 45px -25px #64461e12,inset -30px 0 50px -28px #64461e0f,inset 0 20px 35px -20px #64461e0d,inset 0 -25px 40px -22px #64461e14}[data-theme=parchemin] .sheet:after{content:"";pointer-events:none;z-index:2;filter:url(#rough-edges);border:4px solid #64461e40;border-width:4px 3px;position:absolute;inset:-4px}[data-theme=parchemin] .sheet:before{content:"";pointer-events:none;z-index:1;background:radial-gradient(at 0 0,#50321438 0%,#0000 22%),radial-gradient(at 100% 0,#50321424 0%,#0000 18%),radial-gradient(at 0 100%,#50321429 0%,#0000 20%),radial-gradient(at 100% 100%,#5032143d 0%,#0000 25%),linear-gradient(47deg,#0000 44.5%,#5a3c1912 44.8% 45.2%,#0000 45.5%),linear-gradient(163deg,#0000 61.5%,#5a3c190f 61.8% 62.2%,#0000 62.5%),linear-gradient(98deg,#0000 72%,#5a3c190d 72.2% 72.5%,#0000 72.7%),linear-gradient(23deg,#0000 28%,#5a3c190a 28.2% 28.5%,#0000 28.7%),linear-gradient(137deg,#0000 83%,#5a3c190d 83.2% 83.5%,#0000 83.7%),linear-gradient(71deg,#0000 55%,#5a3c190a 55.2% 55.5%,#0000 55.7%);position:absolute;inset:0}[data-theme=parchemin] .header{background:radial-gradient(at 50% 0,#78551e26 0%,#0000 60%),linear-gradient(#c4ad82 0%,#d0bc96 50%,#d8c8a4 100%);border-bottom:2px solid #64461e59}[data-theme=parchemin] .header:before{background:0 0}[data-theme=parchemin] .header-ornament{font-family:var(--font-heading);color:#6b4c2a;letter-spacing:6px;font-size:13px}[data-theme=parchemin] .char-name{font-family:var(--font-title);background:linear-gradient(135deg,#3a2008 0%,#5a3810 40%,#7a5418 100%);letter-spacing:2px;-webkit-background-clip:text;background-clip:text;border-bottom:1px solid #50320f40}[data-theme=parchemin] .char-subtitle{font-family:var(--font-heading);letter-spacing:3px;font-size:14px}[data-theme=parchemin] .dhampire-tag{font-family:var(--font-heading);color:#6a1818;background:#64141414;border:1px solid #64141459;border-radius:0}[data-theme=parchemin] .level-badge{font-family:var(--font-heading);color:#5a3d18;background:#78551e1a;border:1px solid #78551e66;border-radius:2px}[data-theme=parchemin] .section{border:none;position:relative}[data-theme=parchemin] .section-title{font-family:var(--font-heading);color:#4a3010;letter-spacing:3px;text-shadow:none;border-bottom:2px solid #64461e40;border-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='4'%3E%3Cfilter id='r'%3E%3CfeTurbulence baseFrequency='0.06' numOctaves='3' seed='7'/%3E%3CfeDisplacementMap in='SourceGraphic' scale='2'/%3E%3C/filter%3E%3Cline x1='0' y1='2' x2='400' y2='2' stroke='rgba(100,70,30,0.35)' stroke-width='1.5' filter='url(%23r)'/%3E%3C/svg%3E") 0 0 2;padding-bottom:6px;font-size:14px}[data-theme=parchemin] .section-title:after{content:"~ ~ ~";text-align:center;font-family:var(--font-body);color:#64461e40;letter-spacing:8px;margin-top:4px;font-size:10px;display:block}[data-theme=parchemin] .info-box,[data-theme=parchemin] .ability,[data-theme=parchemin] .stat-box{box-shadow:none;background:0 0;border:1px solid #64461e40;border-radius:0;position:relative}[data-theme=parchemin] .info-box{border-style:dashed}[data-theme=parchemin] .ability{border:1px solid #64461e4d}[data-theme=parchemin] .ability:hover{border-color:#64461e80}[data-theme=parchemin] .stat-box{border:2px solid #64461e4d}[data-theme=parchemin] .info-label,[data-theme=parchemin] .ability-name,[data-theme=parchemin] .stat-label{font-family:var(--font-heading);color:#7a5a30}[data-theme=parchemin] .stat-value{font-family:var(--font-title);color:#4a3010}[data-theme=parchemin] .ability-mod{font-family:var(--font-body);color:var(--accent)}[data-theme=parchemin] .feature-box{filter:url(#rough-border);background:#c8af821f;border:none;border-left:3px solid #64461e59;border-radius:0;padding-left:14px}[data-theme=parchemin] .feature-box .feature-name{font-family:var(--font-heading)}[data-theme=parchemin] .feature-box .feature-desc{font-family:var(--font-body);font-style:italic}[data-theme=parchemin] .feature-box.blood{background:#7814140f;border-left-color:#7a2020}[data-theme=parchemin] .feature-box.gold{background:#785a140f;border-left-color:#7a5a14}[data-theme=parchemin] .feature-box.race{border-left-color:var(--race-accent2);background:#64461e0f}[data-theme=parchemin] .pip{background:#f0e6cd80;border:2px solid #5a3c1980;border-radius:2px;box-shadow:inset 0 1px 2px #64461e14}[data-theme=parchemin] .pip.used{background:radial-gradient(circle at 40% 35%,#b02020 0%,#7a1010 70%,#5a0a0a 100%);border-color:#4a0808;box-shadow:inset 0 1px 3px #00000040,0 1px 3px #640f0f33}[data-theme=parchemin] .pip:hover{background:#781e1e1a;border-color:#781e1e80}[data-theme=parchemin] .skill-dot{background:#f0e6cd66;border-color:#5a3c1980}[data-theme=parchemin] .skill-dot.proficient{background:var(--accent);border-color:var(--accent)}[data-theme=parchemin] .skill-dot.expertise{background:var(--gold);border-color:var(--gold);box-shadow:0 0 5px #78551466}[data-theme=parchemin] .skill-row{font-family:var(--font-body)}[data-theme=parchemin] .badge{font-family:var(--font-heading);background:#b49b6e26;border:1px solid #64461e59;border-radius:2px}[data-theme=parchemin] .type-badge{border-color:#64461e4d;border-radius:2px}[data-theme=parchemin] .spell-tag{font-family:var(--font-heading);background:#b49b6e1f;border-color:#64461e4d;border-radius:2px;font-size:10px}[data-theme=parchemin] .spell-card-title{font-family:var(--font-heading)}[data-theme=parchemin] input,[data-theme=parchemin] textarea,[data-theme=parchemin] select{color:var(--text);font-family:var(--font-body)}[data-theme=parchemin] .info-value-input,[data-theme=parchemin] .ability-score input,[data-theme=parchemin] .stat-input{font-family:var(--font-body);border-bottom:1px solid #5a3c194d}[data-theme=parchemin] .styled-select,[data-theme=parchemin] .equip-input,[data-theme=parchemin] .cf-input,[data-theme=parchemin] .money-input,[data-theme=parchemin] .small-input{font-family:var(--font-body);background:#e6d7b466;border:1px solid #64461e4d;border-radius:0}[data-theme=parchemin] textarea{font-family:var(--font-body);background:#e6d7b459;border:1px solid #64461e40;border-radius:0;font-style:italic}[data-theme=parchemin] .btn-levelup{font-family:var(--font-heading);color:#3a2008;background:linear-gradient(135deg,#78551e26,#78551e4d);border:1px solid #64461e80;border-radius:2px}[data-theme=parchemin] .btn-confirm{font-family:var(--font-heading);color:#fff;text-shadow:0 1px 1px #0000004d;border-radius:2px}[data-theme=parchemin] .btn-cancel{font-family:var(--font-heading);color:#5a3d18;border:1px solid #64461e66;border-radius:2px}[data-theme=parchemin] .btn-add{font-family:var(--font-heading);color:#5a3d18;background:#64461e14;border:1px dashed #64461e66;border-radius:0}[data-theme=parchemin] .btn-roll{font-family:var(--font-heading);color:#5a3d18;border:1px solid #78551e80;border-radius:2px}[data-theme=parchemin] .btn-back-home{font-family:var(--font-heading);color:#5a3d18;border-color:#64461e66;border-radius:2px}[data-theme=parchemin] .btn-short-rest,[data-theme=parchemin] .btn-long-rest{font-family:var(--font-heading);border:1px solid #64461e66;border-radius:2px}[data-theme=parchemin] .modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#28190acc}[data-theme=parchemin] .modal{font-family:var(--font-body);background:radial-gradient(at 25% 15%,#8c64321a 0%,#0000 50%),radial-gradient(at 75% 85%,#825a2814 0%,#0000 45%),linear-gradient(170deg,#ecdcb8 0%,#f0e2c4 30%,#e8d4b0 70%,#ecdcb8 100%);border:3px double #64461e66;border-left:none;border-right:none;border-radius:2px;box-shadow:0 8px 40px #28190a59,inset 0 0 60px #7855280d}[data-theme=parchemin] .modal-title{font-family:var(--font-title);color:#4a3010}[data-theme=parchemin] .modal-section-title{font-family:var(--font-heading);color:#5a3d18}[data-theme=parchemin] .modal-step{font-family:var(--font-heading);border-radius:2px}[data-theme=parchemin] .modal-step.completed{color:#fff}[data-theme=parchemin] .modal-step.has-error{color:#8b0000;background:#8b000026;border-color:#8b0000}[data-theme=parchemin] .validation-error-msg{color:#8b0000;background:#8b000014;border-left-color:#8b0000}[data-theme=parchemin] .modal-select-inline,[data-theme=parchemin] .modal-select-inline option{font-family:var(--font-body);color:var(--text);background:#e6d7b480;border-radius:0}[data-theme=parchemin] .picker-overlay{background:#28190abf}[data-theme=parchemin] .picker-modal{font-family:var(--font-body);background:linear-gradient(170deg,#ecdcb8,#f0e2c4 40%,#e8d4b0 100%);border:3px double #64461e66;border-left:none;border-right:none;border-radius:2px;box-shadow:0 8px 40px #28190a59}[data-theme=parchemin] .picker-title{font-family:var(--font-heading)}[data-theme=parchemin] .equip-row{border-bottom:1px dashed #64461e26}[data-theme=parchemin] .equip-cat-label,[data-theme=parchemin] .skills-header{font-family:var(--font-heading)}[data-theme=parchemin] .spell-upcast.blood{color:#7a2020;background:#7814140f;border-left-color:#7a2020}[data-theme=parchemin] .color-mode-select{font-family:var(--font-body);color:#3a2008;background:#e6d7b480;border:1px solid #64461e66;border-radius:2px}.sheet{background:var(--bg-mid);border:1px solid var(--border2);border-radius:var(--radius-xl);max-width:920px;margin:0 auto;overflow:hidden;box-shadow:0 0 80px #7c3aed26,0 0 160px #8b00000d}.header{border-bottom:2px solid var(--border2);background:linear-gradient(135deg,#0a0d14 0%,#130d1e 50%,#0d0a14 100%);padding:30px;position:relative;overflow:hidden}.header:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#7c3aed1f 0%,#0000 70%);position:absolute;inset:0}.header-ornament{text-align:center;color:var(--accent3);letter-spacing:8px;text-transform:uppercase;opacity:.6;margin-bottom:12px;font-family:Cinzel,serif;font-size:11px}.header-avatar{cursor:pointer;border-radius:50%;flex-shrink:0;width:96px;height:96px;transition:transform .2s,box-shadow .2s;overflow:hidden}.header-avatar:hover{transform:scale(1.06);box-shadow:0 0 16px #d4a85380}.header-avatar canvas,.header-avatar .header-avatar-img{object-fit:cover;border-radius:50%;width:96px;height:96px;display:block}.header-avatar.header-avatar-fullbody{border-radius:var(--radius-md,6px);width:72px;height:108px}.header-avatar.header-avatar-fullbody .header-avatar-img{border-radius:var(--radius-md,6px);object-position:top;width:72px;height:108px}.header-main{justify-content:center;align-items:center;gap:20px;display:flex}.char-name-wrap{text-align:center}.char-name{background:linear-gradient(135deg, var(--gold) 0%, var(--gold2) 50%, var(--accent3) 100%);-webkit-text-fill-color:transparent;letter-spacing:3px;cursor:text;-webkit-background-clip:text;background-clip:text;border-bottom:1px dashed #d4a8534d;min-width:200px;padding-bottom:2px;font-family:Cinzel Decorative,serif;font-size:36px;font-weight:700;display:inline-block}.char-name:focus{border-bottom-color:var(--gold);outline:none}.char-subtitle{color:var(--text-dim);letter-spacing:2px;margin-top:8px;font-family:Cinzel,serif;font-size:13px}.dhampire-tag{border:1px solid var(--blood2);color:var(--color-warning);letter-spacing:2px;background:var(--blood-bg-mid);border-radius:20px;margin-top:10px;padding:5px 20px;font-family:Cinzel,serif;font-size:12px;display:inline-block}.level-section{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;margin-top:16px;display:flex}.level-badge{color:var(--gold2);background:var(--gold-bg-mid);border:1px solid var(--gold);border-radius:var(--radius-lg);letter-spacing:1px;padding:6px 20px;font-family:Cinzel,serif;font-size:15px}.btn-levelup{background:linear-gradient(135deg, var(--accent), var(--blood2));border:1px solid var(--accent2);border-radius:var(--radius-lg);color:#fff;cursor:pointer;letter-spacing:1px;padding:6px 18px;font-family:Cinzel,serif;font-size:12px;transition:all .2s}.btn-levelup:hover{filter:brightness(1.2);box-shadow:0 0 12px var(--glow-purple)}.btn-levelup:disabled{opacity:.4;cursor:not-allowed;filter:none}.section{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);margin-bottom:14px;padding:16px}.section-title{text-transform:uppercase;letter-spacing:3px;color:var(--accent3);border-bottom:1px solid var(--border);margin-bottom:14px;padding-bottom:8px;font-family:Cinzel,serif;font-size:12px}.content{padding:16px}.two-col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.personality-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.personality-label{color:var(--text-muted);margin-bottom:4px;font-family:Cinzel,serif;font-size:12px}.info-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.info-box{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px}.info-label{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:4px;font-family:Cinzel,serif;font-size:9px}.info-value{color:var(--text);font-size:17px;font-weight:600}.info-value-input{color:var(--text);border:none;border-bottom:1px dashed var(--border2);background:0 0;width:100%;padding:2px 0;font-family:Crimson Text,serif;font-size:16px;font-weight:600}.info-value-input:focus{border-bottom-color:var(--accent3);outline:none}select.info-value-input option{background:var(--bg-card);color:var(--text)}.abilities{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.ability{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:12px 6px;transition:border-color .2s}.ability:hover{border-color:var(--accent2)}.ability-name{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:6px;font-family:Cinzel,serif;font-size:8px}.ability-score input{color:var(--text);border:none;border-bottom:1px dashed var(--border2);text-align:center;background:0 0;width:44px;padding:0;font-family:Cinzel,serif;font-size:22px;font-weight:700}.ability-score input:focus{border-bottom-color:var(--accent3);outline:none}.ability-mod{color:var(--accent3);font-family:Cinzel,serif;font-size:16px;font-weight:700}.ability-penalty{color:var(--color-warning);margin-top:2px;font-family:Cinzel,serif;font-size:10px}.combat-stats{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.stat-label{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:6px;font-family:Cinzel,serif;font-size:9px}.stat-value{color:var(--gold2);font-family:Cinzel,serif;font-size:26px;font-weight:700}.stat-input{color:var(--gold2);border:none;border-bottom:1px solid var(--border2);text-align:center;background:0 0;width:70px;font-family:Cinzel,serif;font-size:24px;font-weight:700}.stat-input:focus{border-bottom-color:var(--gold);outline:none}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.hp-bar{background:var(--border);border-radius:3px;width:100%;height:6px;margin-top:6px;overflow:hidden}.hp-fill{background:linear-gradient(90deg, var(--blood2), var(--red-soft));border-radius:3px;height:100%;transition:width .3s}.skills-grid{grid-template-columns:1fr 1fr;gap:4px;display:grid}.skill{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:4px 6px;font-size:13px;display:flex}.skill-dot{border:1px solid var(--border2);border-radius:50%;flex-shrink:0;width:12px;height:12px}.skill-dot.proficient{background:var(--accent);border-color:var(--accent2)}.skill-dot.expertise{background:var(--gold);border-color:var(--gold2);box-shadow:0 0 6px var(--glow-gold)}.skill-name{color:var(--text);flex:1;font-size:13px}.skill-mod{color:var(--accent3);text-align:right;min-width:28px;font-family:Cinzel,serif;font-size:12px;font-weight:600}.feature-box{border-left:3px solid var(--accent);background:var(--accent-bg-low);border-radius:0 var(--radius-md) var(--radius-md) 0;margin-bottom:10px;padding:10px 12px}.feature-box.blood{border-left-color:var(--blood2);background:var(--blood-bg-low)}.feature-box.gold{border-left-color:var(--gold);background:var(--gold-bg-low)}.feature-box.race{border-left-color:var(--race-accent2);background:var(--race-bg-low)}.feature-name{color:var(--accent3);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:5px;font-family:Cinzel,serif;font-size:13px;display:flex}.feature-box.blood .feature-name{color:var(--color-warning)}.feature-box.gold .feature-name{color:var(--gold2)}.feature-box.race .feature-name{color:var(--race-accent3)}.feature-text{color:var(--text-dim);font-size:13px;line-height:1.7}.badge{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0d;border-radius:10px;padding:1px 8px;font-family:Cinzel,serif;font-size:10px;font-weight:400}.slot-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.slot-label{color:var(--text-muted);min-width:80px;font-family:Cinzel,serif;font-size:11px}.slot-pip{border:2px solid var(--accent2);cursor:pointer;border-radius:50%;width:20px;height:20px;margin-right:3px;transition:all .15s;display:inline-block}.slot-pip.used{background:var(--blood2);border-color:var(--blood)}.slot-pip:hover{background:#a855f74d}.hands-pip-grid{flex-wrap:wrap;align-items:center;gap:3px;margin-top:4px;display:flex}.hands-pip-row-break{flex-basis:100%;height:0}.hands-pip{border:1.5px solid var(--accent2);border-radius:var(--radius-sm);cursor:pointer;width:26px;height:26px;color:var(--accent2);-webkit-user-select:none;user-select:none;background:0 0;justify-content:center;align-items:center;font-family:Cinzel,serif;font-size:9px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.hands-pip.used{background:var(--accent);color:var(--bg-deep);border-color:var(--accent)}.hands-pip:hover:not(.used){border-color:var(--accent3);background:var(--accent-bg-low)}.hands-pip.used:hover{background:var(--accent2)}.insp-pip{border:2px solid var(--gold);border-radius:var(--radius-sm);cursor:pointer;width:22px;height:22px;margin-right:4px;transition:all .15s;display:inline-block}.insp-pip.used{background:var(--gold)}.insp-pip:hover{background:#d4a8534d}.pip{border:2px solid var(--blood);cursor:pointer;border-radius:50%;width:18px;height:18px;margin-right:4px;transition:all .15s;display:inline-block}.pip.used{background:var(--blood2);border-color:var(--blood)}.pip:hover{background:var(--blood-bg-high)}.rest-pip{border:2px solid var(--teal);border-radius:50%;width:18px;height:18px;transition:all .15s;display:inline-block}.rest-pip.used{background:var(--teal)}.btn-roll:disabled{opacity:.35;cursor:not-allowed}.spell-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:10px;padding:12px}.spell-card:hover{border-color:var(--border2)}.spell-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.spell-name{color:var(--accent3);font-family:Cinzel,serif;font-size:13px;font-weight:600}.spell-card.niv1 .spell-name{color:var(--gold2)}.spell-card.niv2 .spell-name{color:var(--color-warning)}.spell-meta{flex-wrap:wrap;gap:6px;display:flex}.spell-tag,.tag{background:var(--accent-bg-high);border:1px solid var(--accent);color:var(--accent3);letter-spacing:1px;border-radius:10px;padding:2px 7px;font-family:Cinzel,serif;font-size:10px;display:inline-block}.spell-tag.gold,.tag.gold{background:var(--gold-bg-mid);border-color:var(--gold);color:var(--gold2)}.spell-tag.blood,.tag.blood{background:var(--blood-bg-high);border-color:var(--blood2);color:var(--color-warning)}.spell-tag.teal,.tag.teal{border-color:var(--teal);color:var(--teal);background:#0d94881f}.spell-tag.fire,.tag.fire{color:#f87171;background:#ef444426;border-color:#ef4444;font-weight:600}.spell-desc{color:var(--text-dim);font-size:13px;line-height:1.6}.spell-upcast{color:var(--accent3);background:var(--accent-bg-low);border-radius:var(--radius-sm);border-left:2px solid var(--accent);margin-top:6px;padding:6px 10px;font-size:12px}.spell-upcast.blood{color:#fca5a5;border-left-color:var(--blood2);background:#8b000014}.spell-section-title{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin:14px 0 8px;font-family:Cinzel,serif;font-size:11px}.spell-innate-pips{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.spell-icon-display{flex-wrap:wrap;gap:8px;margin-bottom:4px;display:flex}.spell-icon-grid{flex-wrap:wrap;gap:8px;margin:6px 0;display:flex}.spell-icon-card{cursor:pointer;border-radius:var(--radius-md);background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:4px;width:80px;padding:4px 4px 6px;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;position:relative}.spell-icon-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 4px 16px #00000060}.spell-icon-card.selected{border-color:var(--accent);box-shadow:0 0 10px var(--accent-bg-high);background:var(--accent-bg-low)}.spell-icon-card.selected .spell-icon-svg{box-shadow:0 0 14px color-mix(in srgb, var(--accent) 40%, transparent)}.spell-icon-svg{border-radius:10px;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.spell-icon-svg svg{border-radius:10px;width:72px;height:72px;display:block}.spell-icon-name{text-align:center;color:var(--text-dim);letter-spacing:.3px;word-break:break-word;max-width:76px;font-family:Cinzel,serif;font-size:9px;line-height:1.3}.spell-icon-tags{flex-wrap:wrap;justify-content:center;gap:3px;display:flex}.spell-icon-info-btn{border:1px solid var(--border);background:var(--bg-card2);width:16px;height:16px;color:var(--text-muted);cursor:pointer;opacity:0;z-index:2;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:10px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:2px;right:2px}.spell-icon-card:hover .spell-icon-info-btn{opacity:1}.spell-icon-card.niv1:hover{border-color:var(--gold)}.spell-icon-card.niv2:hover{border-color:var(--color-warning)}.spell-icon-card.niv3:hover{border-color:#f84}.spell-icon-card.niv4:hover{border-color:#f66}.spell-icon-card.niv5:hover,.spell-icon-card.niv6:hover,.spell-icon-card.niv7:hover,.spell-icon-card.niv8:hover,.spell-icon-card.niv9:hover{border-color:var(--blood2)}.spell-icon-card.niv1.selected{border-color:var(--gold);box-shadow:0 0 10px var(--gold-bg-low);background:var(--gold-bg-low)}.spell-icon-card.niv2.selected,.spell-icon-card.niv3.selected{border-color:var(--color-warning);box-shadow:0 0 10px #fb923c26}.spell-tooltip{z-index:1000;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-lg);flex-direction:column;gap:8px;width:300px;max-width:calc(100vw - 16px);padding:14px 16px;display:none;position:absolute;box-shadow:0 8px 32px #00000080}.spell-tooltip.open{display:flex}.spell-tooltip-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1;position:absolute;top:8px;right:10px}.spell-tooltip-close:hover{color:var(--text)}.spell-tooltip-name{color:var(--gold2);padding-right:20px;font-family:Cinzel,serif;font-size:13px;font-weight:600}.spell-tooltip-meta{flex-wrap:wrap;gap:4px;display:flex}.spell-tooltip-desc{color:var(--text-dim);font-family:Crimson Text,serif;font-size:13px;line-height:1.6}[data-theme=parchemin] .spell-tooltip{background:#f5ead8;border-color:#b8956a;box-shadow:0 8px 32px #00000040}[data-theme=parchemin] .spell-tooltip-name{color:#7a4a1e}[data-theme=parchemin] .spell-tooltip-desc{color:#5a3a1a}[data-theme=parchemin] .beast-tooltip{background:#f5ead8;border-color:#b8956a;box-shadow:0 8px 32px #00000040}[data-theme=parchemin] .spell-icon-name{color:#6a4020}[data-theme=parchemin] .spell-icon-card:hover{border-color:#b8956a}.sens-skill-btns{flex-wrap:wrap;gap:8px;display:flex}.sens-skill-btn{border-radius:var(--radius-md);border:1px solid var(--border2);background:var(--bg-card2);color:var(--text-dim);cursor:pointer;padding:6px 16px;font-family:Cinzel,serif;font-size:12px;transition:background .15s,border-color .15s,color .15s}.sens-skill-btn:hover{border-color:var(--accent);color:var(--accent3)}.sens-skill-btn.active{background:var(--accent-bg-mid);border-color:var(--accent);color:var(--accent3)}.attack-card{background:var(--bg-card2);border:1px solid var(--border);border-left:3px solid var(--blood2);border-radius:var(--radius-md);margin-bottom:8px;padding:10px 12px}.attack-line{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.attack-name{color:var(--accent3);flex:1;min-width:0;font-family:Cinzel,serif;font-size:13px;font-weight:600}.attack-bonus{color:var(--gold2);white-space:nowrap;font-family:Cinzel,serif;font-size:13px;font-weight:700}.attack-damage{color:var(--color-warning);white-space:nowrap;font-family:Cinzel,serif;font-size:12px}.attack-range{color:var(--text-muted);white-space:nowrap;font-family:Crimson Text,serif;font-size:12px}.attack-mastery-line{color:var(--text-dim);align-items:baseline;gap:7px;margin-top:5px;font-family:Crimson Text,serif;font-size:12.5px;display:flex}.attack-mastery-name{border-radius:var(--radius-sm);background:var(--blood-bg-mid);border:1px solid var(--blood2);color:var(--color-warning);white-space:nowrap;flex-shrink:0;padding:1px 7px;font-family:Cinzel,serif;font-size:10px}.attack-special-line{color:var(--text-dim);align-items:baseline;gap:7px;margin-top:5px;font-family:Crimson Text,serif;font-size:12.5px;display:flex}.attack-special-name{border-radius:var(--radius-sm);background:var(--gold-bg-low);border:1px solid var(--gold2);color:var(--gold2);white-space:nowrap;flex-shrink:0;padding:1px 7px;font-family:Cinzel,serif;font-size:10px}.attack-special-dmg{color:var(--gold);white-space:nowrap;flex-shrink:0;font-family:Cinzel,serif;font-size:12px}.attack-special-desc{flex:1}[data-rest=court]:after,[data-rest=long]:after{letter-spacing:.02em;white-space:nowrap;align-self:center;margin-left:8px;font-family:Cinzel,serif;font-size:10px}[data-rest=court]:after{content:"⏱ Repos court";color:var(--color-safe)}[data-rest=long]:after{content:"🌙 Repos long";color:var(--accent2)}.attack-embedded-spell{background:var(--accent-bg-low);border-color:var(--accent2);margin-top:8px;margin-bottom:0;padding:8px 10px}.attack-embedded-spell .spell-name,.attack-embedded-spell .spell-desc{font-size:12px}.attack-embedded-spell .spell-upcast{font-size:11.5px}.attack-spell-line{color:var(--accent2);align-items:center;gap:8px;margin-top:4px;padding:2px 4px;font-family:Crimson Text,serif;font-size:12.5px;font-style:italic;display:flex}.attack-spell-name{flex:1}.attack-spell-uses{color:var(--text-muted);white-space:nowrap;font-family:Cinzel,serif;font-size:11px;font-style:normal}.equip-zone{margin-bottom:14px}.equip-zone-title{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:6px;font-family:Cinzel,serif;font-size:11px;display:flex}.equip-row{align-items:center;gap:8px;margin-bottom:5px;display:flex}.equip-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:0;color:var(--text);flex:1;padding:5px 10px;font-family:Crimson Text,serif;font-size:14px}.equip-input:focus{border-color:var(--accent2);outline:none}.btn-add,.btn-del{border-radius:var(--radius-sm);border:1px solid var(--border2);cursor:pointer;padding:4px 10px;font-size:14px;transition:all .15s}.btn-add{background:var(--accent-bg-high);color:var(--accent3)}.btn-add:hover{background:#7c3aed4d}.btn-del{background:var(--blood-bg-high);color:var(--color-warning)}.btn-del:hover{background:#8b00004d}.sac-qty-ctrl{flex-shrink:0;align-items:center;gap:2px;display:flex}.sac-qty{text-align:center;min-width:28px;color:var(--gold2);padding:0 3px;font-family:Cinzel,serif;font-size:13px;font-weight:600}.btn-qty{border-radius:var(--radius-sm);border:1px solid var(--border2);cursor:pointer;width:24px;height:24px;padding:0;font-size:15px;line-height:1;transition:all .15s}.btn-qty-plus{background:var(--accent-bg-mid);color:var(--accent3)}.btn-qty-plus:hover{background:var(--accent-bg-high)}.btn-qty-minus{background:var(--blood-bg-mid);color:var(--color-warning)}.btn-qty-minus:hover{background:var(--blood-bg-high)}.type-badge{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;align-items:center;padding:1px 6px;font-family:Cinzel,serif;font-size:9px;font-weight:700;line-height:1.6;display:inline-flex}.type-torse{background:var(--gold-bg-mid);color:var(--gold2);border:1px solid #d4a85359}.type-bouclier{color:#c9a84c;background:#b496501f;border:1px solid #b4965059}.type-tete{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf244d}.type-mains{color:#9ca3af;background:#9ca3af1a;border:1px solid #9ca3af4d}.type-pieds{color:#b4825a;background:#b482501f;border:1px solid #b482504d}.type-anneau{color:#d4a853;background:#d4a8531a;border:1px solid #d4a8534d}.type-cape{color:var(--teal);background:#0d94881a;border:1px solid #0d94884d}.type-amulette{background:var(--blood-bg-low);color:var(--blood2);border:1px solid #8b00004d}.type-arme{background:var(--blood-bg-mid);color:var(--color-warning);border:1px solid #8b000066}.type-potion{color:#f87171;background:#ef44441a;border:1px solid #ef44444d}.type-parchemin{color:#ca8a04;background:#eab3081a;border:1px solid #eab3084d}.type-baguette{background:var(--accent-bg-low);color:var(--accent3);border:1px solid #7c3aed4d}.type-baton{color:#a78bfa;background:#7c3aed1a;border:1px solid #7c3aed4d}.type-instrument{background:var(--accent-bg-mid);color:var(--accent3);border:1px solid #7c3aed66}.type-outil{color:var(--teal);background:#0d94881a;border:1px solid #0d948859}.type-autre{color:var(--text-muted);border:1px solid var(--border);background:0 0}.picker-overlay{z-index:600;opacity:0;pointer-events:none;background:#000000bf;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.picker-overlay.open{opacity:1;pointer-events:all}.picker-modal{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-lg);flex-direction:column;gap:12px;width:min(520px,95vw);max-height:82vh;padding:20px;display:flex;box-shadow:0 8px 40px #0009}.picker-header{justify-content:space-between;align-items:center;display:flex}.picker-title{color:var(--gold2);letter-spacing:1px;font-family:Cinzel,serif;font-size:15px;font-weight:700}.picker-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:16px;transition:color .15s}.picker-close:hover{color:var(--text)}.picker-search{background:var(--bg-mid);border:1px solid var(--border2);border-radius:var(--radius-md);width:100%;color:var(--text);box-sizing:border-box;padding:8px 12px;font-family:Crimson Text,serif;font-size:13px}.picker-search:focus{border-color:var(--accent);outline:none}.picker-filters{flex-wrap:wrap;gap:6px;display:flex}.picker-chip{border:1px solid var(--border2);background:var(--bg-mid);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border-radius:999px;padding:3px 12px;font-family:Cinzel,serif;font-size:10px;transition:all .15s}.picker-chip:hover{border-color:var(--accent);color:var(--accent3)}.picker-chip.active{background:var(--accent-bg-mid);border-color:var(--accent);color:var(--accent3)}.picker-list{flex-direction:column;gap:2px;max-height:380px;display:flex;overflow-y:auto}.picker-item{border-radius:var(--radius-sm);background:var(--bg-mid);cursor:pointer;text-align:left;border:1px solid #0000;flex-wrap:wrap;align-items:center;gap:6px;width:100%;padding:6px 10px;transition:all .15s;display:flex}.picker-item:hover{background:var(--accent-bg-low);border-color:var(--border2)}.picker-item-name{color:var(--text);flex:1;font-family:Crimson Text,serif;font-size:14px}.picker-item-stat{color:var(--text-dim);white-space:nowrap;flex-shrink:0;margin-left:auto;padding-right:6px;font-family:Cinzel,serif;font-size:10px}.picker-item-cout{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-family:Cinzel,serif;font-size:10px}.picker-item-desc{width:100%;color:var(--text-muted);margin-top:1px;font-family:Crimson Text,serif;font-size:11px;font-style:italic;line-height:1.3}.picker-empty{text-align:center;color:var(--text-muted);padding:24px;font-family:Crimson Text,serif;font-style:italic}.picker-btn-row{justify-content:flex-end;gap:8px;display:flex}.picker-create-panel{flex-direction:column;gap:10px;max-height:440px;display:flex;overflow-y:auto}.picker-create-panel.hidden{display:none}.cf-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding-bottom:6px;display:flex}.cf-title{color:var(--gold2);font-family:Cinzel,serif;font-size:13px;font-weight:600}.cf-back-btn{padding:5px 12px;font-size:12px}.cf-row{flex-direction:column;gap:4px;display:flex}.cf-row-2col{grid-template-columns:1fr 1fr;gap:10px;display:grid}.cf-center{align-items:flex-end;padding-bottom:6px;display:flex}.cf-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-family:Cinzel,serif;font-size:10px}.cf-input{background:var(--bg-mid);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);box-sizing:border-box;width:100%;padding:6px 10px;font-family:Crimson Text,serif;font-size:13px;transition:border-color .15s}.cf-input:focus{border-color:var(--accent);outline:none}.cf-textarea{resize:vertical;min-height:48px;font-family:Crimson Text,serif;font-size:13px;line-height:1.4}.cf-dmg-entries-list{flex-direction:column;gap:4px;display:flex}.cf-dmg-entry{align-items:center;gap:6px;display:flex}.cf-dmg-dice{flex-shrink:0;width:68px}.cf-dmg-type{flex:1;min-width:0}.cf-rmv-dmg-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;flex-shrink:0;padding:0 7px;font-size:15px;line-height:1.6;transition:color .15s,border-color .15s}.cf-rmv-dmg-btn:hover{color:var(--blood);border-color:var(--blood)}.cf-add-dmg-btn{border:1px dashed var(--border2);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;background:0 0;width:100%;margin-top:2px;padding:4px 10px;font-family:Cinzel,serif;font-size:11px;transition:color .15s,border-color .15s}.cf-add-dmg-btn:hover{color:var(--gold);border-color:var(--gold)}.cf-sa-list,.cf-gs-list{flex-direction:column;gap:6px;display:flex}.cf-sa-entry,.cf-gs-entry{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:4px;padding:8px;display:flex;position:relative}.cf-sa-entry-header,.cf-gs-entry-header{align-items:center;gap:6px;display:flex}.cf-sa-name,.cf-gs-name{flex:1;min-width:0}.cf-gs-uses{flex-shrink:0;width:52px}.cf-gs-reset{flex-shrink:0;width:120px}.cf-entry-rmv-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:color .15s}.cf-entry-rmv-btn:hover{color:var(--blood)}.cf-add-entry-btn{border:1px dashed var(--border2);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;background:0 0;width:100%;margin-top:2px;padding:4px 10px;font-family:Cinzel,serif;font-size:11px;transition:color .15s,border-color .15s}.cf-add-entry-btn:hover{color:var(--accent2);border-color:var(--accent2)}.cf-subpanel{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:8px;padding:10px;display:flex}.cf-checks-row{flex-wrap:wrap;gap:16px;display:flex}.cf-checkbox-wrap{color:var(--text-dim);cursor:pointer;align-items:center;gap:6px;font-family:Crimson Text,serif;font-size:13px;display:flex}.cf-checkbox-wrap input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:14px;height:14px}.cf-props-grid{grid-template-columns:repeat(2,1fr);gap:6px 12px;display:grid}.cf-submit-btn{align-self:flex-end;margin-top:4px}.money-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.money-box{text-align:center}.money-label{letter-spacing:1px;margin-bottom:4px;font-family:Cinzel,serif;font-size:10px}.money-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);text-align:center;padding:6px 4px;font-family:Cinzel,serif;font-size:18px;font-weight:700}.money-input:focus{border-color:var(--gold);outline:none}.pc .money-label{color:#cd7f32}.pa .money-label{color:silver}.pe .money-label{color:#50c878}.po .money-label{color:var(--gold2)}.pp .money-label{color:#e5e4e2}.hunger-tracker{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.hunger-day{border:2px solid var(--border2);border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-dim);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:1px;font-family:Cinzel,serif;font-size:10px;transition:all .15s;display:flex}.hunger-day .day-label{font-size:9px}.hunger-day .day-penalty{color:var(--text-muted);font-size:9px}.hunger-day.safe{border-color:var(--teal)}.hunger-day.fed{background:var(--teal);border-color:var(--teal);color:#fff}.hunger-day.danger{border-color:var(--red-soft)}.hunger-day.danger-fed{border-color:var(--red-soft);color:#fca5a5;background:#dc26264d}.hunger-day:hover{filter:brightness(1.3)}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}.hunger-day.danger:not(.danger-fed){animation:1.5s ease-in-out infinite pulse}.penalty-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.penalty-badge{border:1px solid var(--red-soft);color:#fca5a5;background:#ef44441a;border-radius:10px;padding:3px 10px;font-family:Cinzel,serif;font-size:11px}.styled-select{background:var(--bg-card2);border:1px solid var(--border2);border-radius:var(--radius-md);color:var(--text);cursor:pointer;width:100%;padding:6px 10px;font-family:Crimson Text,serif;font-size:14px}.styled-select:focus{border-color:var(--accent2);outline:none}.check-input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.small-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);width:55px;color:var(--gold2);text-align:center;padding:3px 5px;font-family:Cinzel,serif;font-size:14px;font-weight:700}.small-input:focus{border-color:var(--gold);outline:none}.notes-area{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-height:80px;color:var(--text);resize:vertical;padding:8px 10px;font-family:Crimson Text,serif;font-size:14px;line-height:1.6}.notes-area:focus{border-color:var(--accent2);outline:none}hr.divider{border:none;border-top:1px solid var(--border);margin:14px 0}.hidden,.class-hidden{display:none!important}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000d9;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--bg-mid);border:1px solid var(--border2);border-radius:var(--radius-xl);width:90%;max-width:560px;max-height:85vh;padding:28px;overflow-y:auto;box-shadow:0 0 60px #7c3aed33}.modal-title{color:var(--gold2);text-align:center;margin-bottom:12px;font-family:Cinzel Decorative,serif;font-size:18px}.modal-step-indicator{justify-content:center;gap:8px;margin-bottom:16px;display:flex}.modal-step{background:var(--bg-card);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;cursor:pointer;border-radius:10px;padding:4px 10px;font-family:Cinzel,serif;font-size:10px;transition:all .2s}.modal-step:hover:not(.active){color:var(--text)}.modal-step.active{background:var(--accent-bg-low);color:var(--accent2);border:1px solid var(--accent)}.modal-step.completed{background:var(--color-safe);color:#fff;border:1px solid var(--color-safe)}.modal-step.has-error{background:var(--blood-bg-mid,#a01e1e40);color:var(--blood,#c0392b);border:1px solid var(--blood,#c0392b);animation:.4s step-error-pulse}.modal-step.has-error.active{background:var(--blood-bg-mid,#a01e1e4d);color:var(--blood,#c0392b);border:1px solid var(--blood,#c0392b)}@keyframes step-error-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.validation-error-msg{color:var(--blood,#c0392b);background:var(--blood-bg-low,#a01e1e1a);border-left:3px solid var(--blood,#c0392b);border-radius:0 var(--radius-sm,4px) var(--radius-sm,4px) 0;margin:4px 0 8px;padding:6px 10px;font-family:Crimson Text,serif;font-size:13px;animation:.25s error-fade-in}@keyframes error-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}[data-section-type].has-error{outline:1px solid var(--blood,#c0392b);outline-offset:2px;border-radius:var(--radius-sm,4px)}.modal-section-title{text-transform:uppercase;letter-spacing:2px;color:var(--accent3);margin-top:16px;margin-bottom:8px;font-family:Cinzel,serif;font-size:11px}.modal-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.modal-label{color:var(--text-dim);min-width:120px;font-size:14px}.modal-btn-row{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.btn-confirm{background:linear-gradient(135deg, var(--accent), var(--blood2));border:1px solid var(--accent2);border-radius:var(--radius-md);color:#fff;cursor:pointer;padding:8px 24px;font-family:Cinzel,serif;font-size:13px;transition:all .2s}.btn-confirm:hover{filter:brightness(1.2)}.btn-cancel{border:1px solid var(--border2);border-radius:var(--radius-md);color:var(--text-dim);cursor:pointer;background:0 0;padding:8px 20px;font-family:Cinzel,serif;font-size:13px}.btn-cancel:hover{border-color:var(--text-dim)}.dice-roll-result{color:var(--gold2);text-align:center;background:var(--gold-bg-mid);border-radius:var(--radius-md);padding:8px 12px;font-family:Cinzel,serif;font-size:28px;font-weight:700}.btn-roll{background:var(--gold-bg-mid);border:1px solid var(--gold);border-radius:var(--radius-md);color:var(--gold2);cursor:pointer;padding:6px 16px;font-family:Cinzel,serif;font-size:12px;transition:all .2s}.btn-roll:hover{background:#d4a8534d}.modal-select-inline{box-sizing:border-box;background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);margin-bottom:4px;padding:.4rem .7rem;font-family:Crimson Text,serif;font-size:.95rem}.modal-select-inline:focus{border-color:var(--accent);outline:none}.modal-select-inline option{background:var(--bg-mid)}.modal-equip-auto{color:var(--text-muted);margin:4px 0 10px;font-family:Crimson Text,serif;font-size:.9rem}.modal-equip-auto strong{color:var(--gold2)}.modal-equip-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:5px;font-family:Cinzel,serif;font-size:.7rem}.equip-picker{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.equip-option{color:var(--text-dim);background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;flex-direction:column;gap:4px;padding:6px 12px;font-family:Crimson Text,serif;font-size:.9rem;transition:border-color .15s,background .15s,color .15s;display:flex}.equip-option-header{align-items:center;gap:6px;display:flex}.equip-option-contenu{color:var(--text-muted);padding-left:4px;font-size:.75rem;line-height:1.4}.equip-option.selected .equip-option-contenu{color:var(--text-dim)}.equip-option:hover{border-color:var(--accent);color:var(--text)}.equip-option.selected{border-color:var(--accent);background:var(--accent-bg-low);color:var(--accent2)}.equip-option-letter{letter-spacing:1px;color:var(--gold2);background:var(--gold-bg-low);border:1px solid var(--gold2);border-radius:3px;padding:1px 5px;font-family:Cinzel,serif;font-size:.65rem;font-weight:700}.equip-option.selected .equip-option-letter{background:var(--accent-bg-mid);border-color:var(--accent);color:var(--accent2)}.check-section{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card2);max-height:180px;padding:10px;overflow-y:auto}.check-section-title{text-transform:uppercase;letter-spacing:2px;color:var(--gold);margin-bottom:6px;padding:4px 0;font-family:Cinzel,serif;font-size:10px}.sort-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:3px 4px;font-size:13px;display:flex}.sort-item:hover{background:var(--accent-bg-mid)}.sort-item input{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px}.sort-item label{cursor:pointer;color:var(--text);flex:1}.spell-info-btn{color:var(--text-muted);cursor:pointer;opacity:.5;-webkit-user-select:none;user-select:none;flex-shrink:0;margin-left:auto;font-size:13px;transition:opacity .15s,color .15s}.spell-info-btn:hover{opacity:1;color:var(--accent3)}.spell-tooltip{background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-md);margin:4px 0 6px;padding:10px 12px;animation:.15s ease-out tooltipIn}@keyframes tooltipIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.spell-tooltip-name{color:var(--accent3);margin-bottom:4px;font-family:Cinzel,serif;font-size:13px}.spell-tooltip-meta{color:var(--text-muted);flex-wrap:wrap;gap:8px;margin-bottom:6px;font-size:11px;display:flex}.spell-tooltip-meta span{background:var(--accent-bg-low);border-radius:var(--radius-sm);padding:1px 6px}.spell-tooltip-desc{color:var(--text-dim);font-size:12px;line-height:1.6}.spell-tooltip-upcast{color:var(--gold);margin-top:6px;font-size:11px;font-style:italic}.feat-preview{border:1px solid var(--gold);border-left:3px solid var(--gold);border-radius:var(--radius-md);background:var(--gold-bg-low);margin-top:10px;padding:10px 12px;animation:.15s ease-out tooltipIn}.feat-preview-name{color:var(--gold2);margin-bottom:4px;font-family:Cinzel,serif;font-size:13px}.feat-preview-desc{color:var(--text-dim);font-size:12px;line-height:1.6}.feat-choice-section{margin-top:8px}.feat-choice-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:4px;font-family:Cinzel,serif;font-size:10px}.feat-choice-fixed{color:var(--accent3);font-family:Cinzel,serif;font-size:13px}.feat-stat-btns{flex-wrap:wrap;gap:4px;display:flex}.feat-stat-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card2);color:var(--text-dim);cursor:pointer;padding:4px 10px;font-family:Cinzel,serif;font-size:11px;font-weight:700;transition:all .15s}.feat-stat-btn:hover{border-color:var(--accent2);color:var(--text)}.feat-stat-btn.active{border-color:var(--gold);background:var(--gold-bg-mid);color:var(--gold2)}.feat-skill-list,.feat-instr-list,.feat-cantrip-list,.feat-spell-list{max-height:140px}.feat-pips-row{align-items:center;gap:8px;margin-top:8px;padding:4px 0;display:flex}.feat-pips-label{color:var(--gold2);white-space:nowrap;font-family:Cinzel,serif;font-size:11px;font-weight:600}.class-picker-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:8px;display:grid}.class-picker-card{border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;background:var(--bg-card2);text-align:center;padding:14px 10px;transition:all .2s}.class-picker-card:hover:not(.disabled){border-color:var(--accent2);transform:translateY(-1px)}.class-picker-card.selected{border-color:var(--accent);background:var(--accent-bg-mid);box-shadow:0 0 12px #7c3aed40}.class-picker-card.disabled{opacity:.45;cursor:not-allowed}.class-picker-icon{margin-bottom:4px;font-size:24px}.class-picker-name{color:var(--accent3);margin-bottom:4px;font-family:Cinzel,serif;font-size:12px}.class-picker-level{color:var(--text-muted);font-size:11px}.class-picker-grid.new-classes .class-picker-card{border-style:dashed}.class-picker-grid.new-classes .class-picker-card.selected{border-style:solid}.sub-select-grid{grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;display:grid}.sub-card{border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;background:var(--bg-card2);padding:12px;transition:all .2s}.sub-card:hover{border-color:var(--accent2)}.sub-card.selected{border-color:var(--accent);background:var(--accent-bg-mid)}.sub-card-name{color:var(--accent3);margin-bottom:5px;font-family:Cinzel,serif;font-size:12px}.sub-card-desc{color:var(--text-muted);font-size:12px;line-height:1.4}.deity-align{letter-spacing:.04em;border-radius:3px;margin-top:5px;padding:2px 6px;font-family:Cinzel,serif;font-size:9px;font-weight:700;display:inline-block}.deity-align.align-good{color:var(--teal);border:1px solid var(--teal);background:#14b8a626}.deity-align.align-neutral{color:var(--gold);border:1px solid var(--gold);background:#c0843426}.deity-align.align-evil{color:var(--blood);border:1px solid var(--blood);background:#b91c1c26}#armor-warning{text-align:left;margin-top:4px}.armor-warn{border-radius:3px;margin-top:2px;padding:2px 6px;font-family:Cinzel,serif;font-size:9px;font-weight:600;line-height:1.5;display:block}.armor-warn-nonprof{color:var(--blood);background:var(--blood-bg-low);border:1px solid var(--blood)}.armor-warn-str{color:var(--color-warning);border:1px solid var(--color-warning);background:#b8870026}.save-indicator{background:var(--bg-card);border:1px solid var(--teal);border-radius:var(--radius-lg);color:var(--teal);opacity:0;pointer-events:none;z-index:200;padding:8px 16px;font-family:Cinzel,serif;font-size:11px;transition:opacity .3s;position:fixed;bottom:20px;right:20px}.save-indicator.show{opacity:1}.save-indicator.error{color:#faa;border-color:var(--blood,#c0392b);background:#a01e1ee6}.sync-banner{background:var(--accent-bg-mid);border:1px solid var(--accent);color:var(--accent2);letter-spacing:1px;border-radius:var(--radius-md);opacity:0;pointer-events:none;z-index:200;padding:5px 16px;font-family:Cinzel,serif;font-size:.72rem;transition:opacity .25s,transform .25s;position:fixed;bottom:56px;left:50%;transform:translate(-50%)translateY(8px)}.sync-banner.show{opacity:1;transform:translate(-50%)translateY(0)}.rest-toast{background:var(--gold-bg-low);border:1px solid var(--gold2);color:var(--gold);letter-spacing:1px;border-radius:var(--radius-md);opacity:0;pointer-events:none;z-index:200;padding:7px 20px;font-family:Cinzel,serif;font-size:.72rem;transition:opacity .25s,transform .25s;position:fixed;top:24px;left:50%;transform:translate(-50%)translateY(-8px)}.rest-toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=768px){body,.content{padding:12px}.sheet{border-radius:var(--radius-lg)}.info-grid,.combat-stats{grid-template-columns:1fr 1fr}.money-grid{grid-template-columns:repeat(3,1fr)}.sub-select-grid,.personality-grid{grid-template-columns:1fr}.picker-modal{width:min(520px,96vw);padding:14px}.picker-list{max-height:300px}.modal{max-width:95vw;padding:20px}.home-container{padding:1.5rem 1rem 3rem}}@media (width<=660px){body{padding:0}.content{padding:10px}.abilities{grid-template-columns:repeat(3,1fr)}.combat-stats{grid-template-columns:1fr 1fr}.two-col{grid-template-columns:1fr}.info-grid{grid-template-columns:1fr 1fr}.skills-grid{grid-template-columns:1fr}.money-grid{grid-template-columns:repeat(3,1fr)}.sub-select-grid{grid-template-columns:1fr}.sheet{border-left:none;border-right:none;border-radius:0;padding-top:52px;padding-bottom:72px}.header{padding:16px 12px}.header-main{flex-direction:column;gap:12px}.header-avatar,.header-avatar canvas,.header-avatar .header-avatar-img{width:72px;height:72px}.header-avatar.header-avatar-fullbody,.header-avatar.header-avatar-fullbody .header-avatar-img{width:54px;height:80px}.header-ornament{letter-spacing:4px;margin-bottom:6px;font-size:9px}.char-name{letter-spacing:1px;font-size:22px}.char-subtitle{letter-spacing:1px;font-size:11px}.level-section{gap:10px;margin-top:10px}.level-badge{padding:5px 12px;font-size:12px}.btn-levelup{padding:5px 12px;font-size:11px}.dhampire-tag{letter-spacing:1px;padding:4px 12px;font-size:10px}.section{margin-bottom:10px;padding:12px 10px}.section-title{letter-spacing:2px;margin-bottom:10px;font-size:11px}.stat-value{font-size:22px}.stat-input{width:60px;font-size:20px}.stat-label{letter-spacing:1px;font-size:8px}.ability{padding:8px 4px}.ability-name{font-size:7px}.ability-score input{width:38px;font-size:18px}.ability-mod{font-size:14px}.personality-grid{grid-template-columns:1fr}.home-header{flex-direction:column;align-items:flex-start;padding-top:48px}.home-container{padding:1rem 1rem 4rem}.home-title{font-size:1.3rem}.rest-section-btns{gap:10px}.btn-rest{padding:7px 18px;font-size:11px}.sac-qty-ctrl{gap:1px}.btn-qty{width:20px;height:20px;font-size:13px}.sac-qty{min-width:22px;font-size:12px}.equip-row{gap:5px}.equip-zone-title{letter-spacing:1px;font-size:10px}.feature-box{padding:8px 10px}.feature-name,.feature-text{font-size:12px}.spell-icon-card{width:68px}.spell-icon-svg,.spell-icon-svg svg{width:60px;height:60px}.spell-icon-name{max-width:64px;font-size:8px}.attack-line{gap:6px}.attack-name,.attack-bonus{font-size:12px}.attack-damage{font-size:11px}.modal{border-radius:0;width:100%;max-width:100vw;height:100%;max-height:100vh;padding:16px}.modal-title{font-size:16px}.modal-btn-row{flex-wrap:wrap;justify-content:center}.picker-modal{border-radius:0;width:100vw;height:100%;max-height:100vh;padding:16px 12px 12px}.picker-close{padding:8px 12px;font-size:22px}.picker-list{max-height:calc(100vh - 280px)}.modal-box{width:92vw;max-height:90vh;padding:24px 20px}.modal-box .modal-row{flex-direction:column;gap:.5rem}.char-desc-panel{flex-direction:column}.save-indicator{padding:6px 12px;font-size:10px;bottom:70px;right:12px}.sync-banner{bottom:70px}.hunger-day{width:32px;height:32px}.beast-grid{grid-template-columns:1fr 1fr}.beast-tooltip{width:calc(100vw - 24px)}.infusion-grid{grid-template-columns:1fr}.slot-label{min-width:60px;font-size:10px}.slot-pip{width:18px;height:18px}.hands-pip{width:22px;height:22px;font-size:8px}.notes-area{padding:6px 8px;font-size:13px}.money-input{padding:5px 2px;font-size:15px}.money-label{font-size:9px}}@media (width<=400px){.char-name{font-size:18px}.abilities{grid-template-columns:repeat(2,1fr)}.combat-stats,.info-grid{grid-template-columns:1fr}.money-grid{grid-template-columns:repeat(3,1fr)}.rest-section-btns{flex-direction:column;align-items:center}.btn-rest{width:180px}.header{padding:12px 8px}.header-ornament{letter-spacing:2px;font-size:8px}.home-container{padding:1rem .75rem 4rem}.spell-icon-card{width:58px}.spell-icon-svg,.spell-icon-svg svg{width:52px;height:52px}.beast-grid{grid-template-columns:1fr}.level-section{flex-direction:column;gap:6px}}.patchnotes{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);margin-top:2.5rem;overflow:hidden}.patchnotes-toggle{text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);cursor:pointer;align-items:center;gap:8px;padding:12px 16px;font-family:Cinzel,serif;font-size:.85rem;list-style:none;transition:color .2s;display:flex}.patchnotes-toggle:hover{color:var(--text)}.patchnotes-toggle:before{content:"▸";font-size:10px;transition:transform .2s}.patchnotes[open]>.patchnotes-toggle:before{transform:rotate(90deg)}.patchnotes-toggle::-webkit-details-marker{display:none}.patchnotes-content{max-height:500px;padding:0 16px 16px;overflow-y:auto}.patchnotes-entry{border-top:1px solid var(--border);padding:12px 0}.patchnotes-entry:first-child{border-top:none}.patchnotes-version{color:var(--gold);margin-bottom:6px;font-family:Cinzel,serif;font-size:.9rem}.patchnotes-date{color:var(--text-muted);font-family:Crimson Text,serif;font-size:.8rem;font-style:italic}.patchnotes-content ul{margin:0;padding-left:1.2em;list-style:"— "}.patchnotes-content li{color:var(--text-dim);margin-bottom:3px;font-family:Crimson Text,serif;font-size:.9rem;line-height:1.5}.patchnotes-content li strong{color:var(--text);font-weight:600}[data-theme=parchemin] .patchnotes{background:#e6d7b44d;border-color:#8b643240}[data-theme=parchemin] .patchnotes-version{color:#5a3e1b}[data-theme=parchemin] .patchnotes-content li strong{color:#3b2a1a}.login-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0d14f5;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);flex-direction:column;gap:16px;width:min(420px,90vw);padding:40px 36px;display:flex;box-shadow:0 0 60px #7c3aed33}.login-ornament{letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);text-align:center;font-family:Cinzel,serif;font-size:11px}.login-title{color:var(--gold);text-align:center;font-family:Cinzel Decorative,serif;font-size:22px}.login-subtitle{color:var(--text-dim);text-align:center;font-family:Crimson Text,serif;font-size:15px}.login-input{background:var(--bg-mid);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);outline:none;padding:10px 14px;font-family:Crimson Text,serif;font-size:15px;transition:border-color .2s}.login-input:focus{border-color:var(--accent2)}.login-btn{background:var(--accent-bg-mid);border:1px solid var(--accent2);border-radius:var(--radius-md);color:var(--accent3);letter-spacing:1px;cursor:pointer;padding:10px;font-family:Cinzel,serif;font-size:13px;transition:background .2s}.login-btn:hover:not(:disabled){background:var(--accent-bg-high)}.login-btn:disabled{opacity:.5;cursor:default}.login-msg{text-align:center;min-height:20px;font-family:Crimson Text,serif;font-size:14px}.user-bar{align-items:center;gap:8px;margin-top:6px;display:flex}.user-email{color:var(--text-muted);letter-spacing:.5px;font-family:Cinzel,serif;font-size:10px}.btn-logout{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);letter-spacing:1px;cursor:pointer;text-transform:uppercase;background:0 0;padding:3px 8px;font-family:Cinzel,serif;font-size:9px;transition:border-color .2s,color .2s}.btn-logout:hover{border-color:var(--blood);color:var(--blood2)}.readonly-banner{background:var(--blood-bg-mid);border-bottom:1px solid var(--blood);color:var(--color-warning);letter-spacing:1px;text-align:center;z-index:500;padding:6px;font-family:Cinzel,serif;font-size:12px;position:fixed;top:0;left:0;right:0}.is-readonly [contenteditable]{pointer-events:none}.is-readonly input:not([type=checkbox]),.is-readonly textarea,.is-readonly select{pointer-events:none;opacity:.7}.is-readonly button:not(.btn-back-home):not(.btn-logout):not(.btn-settings-gear):not(.btn-back-fixed){pointer-events:none;opacity:.4}.btn-back-home{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;background:0 0;padding:3px 8px;font-family:Cinzel,serif;font-size:9px;text-decoration:none;transition:border-color .2s,color .2s;display:inline-block}.btn-back-home:hover{border-color:var(--accent2);color:var(--accent2)}.color-mode-select{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:100%;padding:6px 10px;font-family:Crimson Text,serif;font-size:13px}.version-tag{z-index:500;color:var(--text-muted);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:Crimson Text,serif;font-size:11px;position:fixed;bottom:10px;left:10px}.btn-back-fixed{z-index:500;position:fixed;top:14px;left:14px}.gear-fixed{z-index:500;position:fixed;top:14px;right:14px}.btn-settings-gear{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:18px;line-height:1;transition:border-color .2s,color .2s;display:flex}.btn-settings-gear:hover{border-color:var(--accent2);color:var(--accent2)}.settings-panel{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-md);z-index:200;flex-direction:column;gap:8px;min-width:210px;padding:10px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 20px #0006}.settings-panel.open{display:flex}.settings-item{width:100%}.settings-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);padding:2px 0;font-family:Cinzel,serif;font-size:10px}.settings-divider{border:none;border-top:1px solid var(--border);margin:2px 0}.settings-panel .btn-back-home{text-align:left;width:100%;padding:6px 8px;display:block}.settings-panel .user-bar{flex-direction:column;align-items:flex-start;gap:6px;padding-top:4px}[data-theme=parchemin] .btn-settings-gear{color:#5a3d18;border-color:#64461e66;border-radius:2px}[data-theme=parchemin] .settings-panel{background:#eedcb5;border-color:#64461e59;box-shadow:2px 4px 16px #3c230a4d}[data-theme=parchemin] .home-page{background:radial-gradient(at 20% 15%,#8b64281f 0%,#0000 55%),radial-gradient(at 80% 85%,#78551e1a 0%,#0000 50%),#e8d5ae}[data-theme=parchemin] .home-container{color:#3b2a1a}[data-theme=parchemin] .home-title{color:#5a3810;text-shadow:1px 1px #c8aa6480;font-family:Cinzel Decorative,serif}[data-theme=parchemin] .home-subtitle{color:#7a5a30}[data-theme=parchemin] .home-header{border-bottom:1px solid #64461e33;padding-bottom:1rem}[data-theme=parchemin] .char-card{background:#f0e1beb3;border:1px solid #64461e4d;border-radius:2px}[data-theme=parchemin] .char-card:hover{border-color:#64461e99}[data-theme=parchemin] .char-card-name{color:#5a3810}[data-theme=parchemin] .char-card-meta{color:#7a5a30}[data-theme=parchemin] .char-card-date{color:#9a7a50}[data-theme=parchemin] .modal-overlay{background:#28190acc}[data-theme=parchemin] .modal-box{background:linear-gradient(170deg,#ecdcb8,#f0e2c4 40%,#e8d4b0 100%);border:1px solid #64461e59;border-radius:2px}[data-theme=parchemin] .modal-title{color:#4a3010;font-family:Cinzel Decorative,serif}[data-theme=parchemin] .modal-label{color:#5a3d18;font-family:Cinzel,serif}[data-theme=parchemin] .modal-input,[data-theme=parchemin] .modal-select{color:#3b2a1a;background:#e6d7b499;border:1px solid #64461e4d;border-radius:0;font-family:Crimson Text,serif}[data-theme=parchemin] .btn-modal-confirm{border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .btn-modal-cancel{color:#5a3d18;border:1px solid #64461e66;border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .user-email{color:#7a5a30}[data-theme=parchemin] .btn-logout{color:#5a3d18;border-color:#64461e66;border-radius:2px}[data-theme=parchemin] .btn-create{color:#3a2008;background:linear-gradient(135deg,#78551e26,#78551e4d);border:1px solid #64461e80;border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .btn-secondary{color:#5a3d18;border-color:#64461e59;border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .btn-back-home{color:#5a3d18;border-color:#64461e66;border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .login-overlay{background:#28190ad9}[data-theme=parchemin] .login-card{background:linear-gradient(160deg,#ecdcb8,#f0e2c4 50%,#e8d4b0 100%);border:1px solid #64461e59;border-radius:2px}[data-theme=parchemin] .login-ornament,[data-theme=parchemin] .login-title{color:#4a3010;font-family:Cinzel Decorative,serif}[data-theme=parchemin] .login-subtitle{color:#7a5a30;font-family:Crimson Text,serif}[data-theme=parchemin] .login-input{color:#3b2a1a;background:#e6d7b499;border:1px solid #64461e4d;border-radius:0;font-family:Crimson Text,serif}[data-theme=parchemin] .login-btn{border-radius:2px;font-family:Cinzel,serif}[data-theme=parchemin] .adv-badge{font-family:var(--font-heading);border-radius:3px}[data-theme=parchemin] .adv-badge-hidden{color:#6a4a28;background:#64461e1a;border-color:#64461e59}[data-theme=parchemin] .adv-badge-open{color:#2a6e60;background:#2a6e601a;border-color:#2a6e6073}[data-theme=parchemin] .adv-badge-code{color:#7a5510;background:#7855141f;border-color:#78551473}[data-theme=parchemin] .adv-badge-request{color:#8b1a1a;background:#8b1a1a1a;border-color:#8b1a1a73}[data-theme=parchemin] .char-badge-admin{font-family:var(--font-heading);color:#7a5510;background:#7855141f;border-color:#78551473;border-radius:3px}[data-theme=parchemin] .char-badge-mine{font-family:var(--font-heading);color:#5a2d82;background:#5a2d8214;border-color:#5a2d8266;border-radius:3px}[data-theme=parchemin] .btn-open{font-family:var(--font-heading);color:#7a5510;background:#7855141a;border-color:#78551473;border-radius:2px}[data-theme=parchemin] .btn-open:hover{background:#78551433}[data-theme=parchemin] .btn-delete{font-family:var(--font-heading);color:#8a6a50;border-color:#64461e4d;border-radius:2px}[data-theme=parchemin] .btn-delete:hover{color:#8b1a1a;border-color:#8b1a1a}.home-page{background:var(--bg-deep);min-height:100vh;color:var(--text)}.home-container{max-width:760px;margin:0 auto;padding:2rem 1.5rem 4rem}.home-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.home-title{color:var(--gold);margin:0;font-family:Cinzel Decorative,serif;font-size:1.6rem}.home-user{color:var(--text-muted);align-items:center;gap:.75rem;font-family:Cinzel,serif;font-size:.75rem;display:flex}.home-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:1.5rem;display:flex}.rest-actions-group{align-items:center;gap:8px;display:flex}.rest-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:10px;margin-bottom:1.5rem;padding:14px 0;display:flex}.rest-section-label{letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);font-family:Cinzel,serif;font-size:10px}.rest-section-btns{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.btn-rest{letter-spacing:1px;border-radius:var(--radius-md);cursor:pointer;border:1px solid;padding:8px 24px;font-family:Cinzel,serif;font-size:12px;transition:all .2s}.btn-short-rest{background:var(--bg-card);border-color:var(--teal);color:var(--teal)}.btn-short-rest:hover{background:#14b8a61f;box-shadow:0 0 10px #14b8a633}.btn-long-rest{background:var(--bg-card);border-color:var(--accent2);color:var(--accent2)}.btn-long-rest:hover{background:var(--accent-bg-low);box-shadow:0 0 10px #8b5cf633}[data-theme=parchemin] .rest-section{border-color:#64461e33}[data-theme=parchemin] .btn-rest{border-radius:2px;font-family:IM Fell English SC,Cinzel,serif}[data-theme=parchemin] .btn-short-rest{color:#4a7a6a;background:#4a7a6a0f;border-color:#4a7a6a}[data-theme=parchemin] .btn-long-rest{color:#5a3d90;background:#5a3d900f;border-color:#5a3d90}.btn-create{letter-spacing:1px;text-transform:uppercase;background:var(--accent-bg-low);border:1px solid var(--accent);border-radius:var(--radius-md);color:var(--accent2);cursor:pointer;padding:.55rem 1.4rem;font-family:Cinzel,serif;font-size:.8rem;transition:background .2s,color .2s}.btn-create:hover{background:var(--accent-bg-mid);color:var(--text)}.char-list{flex-direction:column;gap:.75rem;display:flex}.char-list-loading,.char-list-empty{color:var(--text-muted);text-align:center;padding:2rem;font-family:Crimson Text,serif;font-size:1rem}.trait-picker{flex-wrap:wrap;gap:6px;display:flex}.trait-chip{border:1px solid var(--border);background:var(--bg-card2);color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;padding:4px 12px;font-family:Crimson Text,serif;font-size:.85rem;transition:all .2s}.trait-chip:hover{border-color:var(--accent);color:var(--text)}.trait-chip.selected{background:var(--accent-bg-mid);border-color:var(--accent);color:var(--gold)}.trait-chip.disabled{opacity:.35;cursor:not-allowed}.modal-hint{color:var(--text-muted);font-family:Crimson Text,serif;font-size:.75rem}.char-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:1rem;padding:1rem 1.25rem;transition:border-color .2s;display:flex}.char-card:hover{border-color:var(--accent)}.char-card-body{flex:1;align-items:center;gap:1rem;min-width:0;display:flex}.char-card-info{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.char-card-name{color:var(--gold);word-break:break-word;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;font-family:Cinzel,serif;font-size:1rem;display:flex}.char-card-meta{color:var(--text-dim);font-family:Crimson Text,serif;font-size:.9rem}.char-badge-mine,.char-badge-admin{letter-spacing:1px;text-transform:uppercase;border-radius:999px;padding:2px 7px;font-family:Cinzel,serif;font-size:.6rem}.char-badge-mine{background:var(--accent-bg-low);border:1px solid var(--accent);color:var(--accent2)}.char-badge-admin{background:var(--gold-bg-low);border:1px solid var(--gold2);color:var(--gold)}.adv-badges{vertical-align:middle;gap:4px;margin-left:6px;display:inline-flex}.adv-badge{letter-spacing:1px;text-transform:uppercase;border-radius:999px;padding:2px 7px;font-family:Cinzel,serif;font-size:.6rem}.adv-badge-hidden{background:var(--bg-card2);border:1px solid var(--border);color:var(--text-muted)}.adv-badge-open{background:var(--accent-bg-low);border:1px solid var(--accent);color:var(--accent2)}.adv-badge-code{background:var(--gold-bg-low);border:1px solid var(--gold2);color:var(--gold)}.adv-badge-request{background:var(--blood-bg-low);border:1px solid var(--blood);color:var(--blood2)}.btn-secondary{border:1px solid var(--border2);color:var(--text-dim);border-radius:var(--radius-md);letter-spacing:.5px;cursor:pointer;background:0 0;align-items:center;gap:6px;padding:6px 16px;font-family:Cinzel,serif;font-size:.8rem;transition:border-color .2s,color .2s;display:inline-flex}.btn-secondary:hover{border-color:var(--accent);color:var(--accent2)}#pending-count{background:var(--blood);color:#fff;text-align:center;border-radius:999px;min-width:16px;padding:1px 5px;font-family:Cinzel,serif;font-size:.65rem;display:inline-block}#pending-count:empty{display:none}.toggle-row{color:var(--text-dim);align-items:center;gap:8px;font-family:Cinzel,serif;font-size:.8rem;display:flex}.char-card-date{color:var(--text-muted);white-space:nowrap;font-family:Crimson Text,serif;font-size:.85rem}.char-card-actions{flex-wrap:wrap;flex-shrink:0;gap:.5rem;display:flex}.btn-open{letter-spacing:.5px;text-transform:uppercase;background:var(--gold-bg-low);border:1px solid var(--gold2);border-radius:var(--radius-sm);color:var(--gold);cursor:pointer;padding:.4rem 1rem;font-family:Cinzel,serif;font-size:.72rem;transition:background .2s}.btn-open:hover{background:var(--gold-bg-mid)}.btn-delete{letter-spacing:.5px;text-transform:uppercase;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;padding:.4rem 1rem;font-family:Cinzel,serif;font-size:.72rem;transition:border-color .2s,color .2s}.btn-delete:hover{border-color:var(--blood);color:var(--blood2)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;position:fixed;inset:0}.modal-box{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-lg);flex-direction:column;gap:1.25rem;width:100%;max-width:420px;max-height:85vh;padding:2rem;display:flex;overflow-y:auto}.avatar-modal-box{max-width:520px}@media (width<=660px){.modal-box{width:92vw;max-width:none;max-height:90vh;padding:24px 16px}.modal-box .modal-row{flex-direction:column;gap:.5rem}.avatar-modal-box{max-width:none}}.modal-title{color:var(--gold);text-align:center;font-family:Cinzel Decorative,serif;font-size:1.1rem}.modal-field{flex-direction:column;flex:1;gap:.3rem;display:flex}.modal-label{letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);font-family:Cinzel,serif;font-size:.7rem}.modal-row{gap:.75rem;display:flex}.modal-input,.modal-select{box-sizing:border-box;background:var(--bg-mid);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);padding:.5rem .75rem;font-family:Crimson Text,serif;font-size:1rem}.modal-input:focus,.modal-select:focus{border-color:var(--accent);outline:none}.modal-select option{background:var(--bg-mid)}.modal-actions{justify-content:center;gap:.75rem;margin-top:.5rem;display:flex}.char-desc-panel{gap:10px;margin-top:10px;margin-bottom:2px;display:flex}.char-desc-col{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;flex:1;gap:3px;min-height:52px;padding:8px 10px;display:flex}.char-desc-col:empty{display:none}.char-desc-label{text-transform:uppercase;letter-spacing:.08em;color:var(--accent3);font-family:Cinzel,serif;font-size:10px}.char-desc-text{color:var(--text-dim);font-family:Crimson Text,serif;font-size:13px;line-height:1.4}.char-desc-physical{color:var(--text-muted);margin-top:2px;font-size:12px;font-style:italic}.char-desc-subrace-label{color:var(--gold);border-top:1px solid var(--border);width:100%;margin-top:6px;padding-top:6px}.modal-btns{justify-content:flex-end;gap:.75rem;display:flex}.btn-modal-cancel{text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;padding:.45rem 1rem;font-family:Cinzel,serif;font-size:.75rem}.btn-modal-cancel:hover{border-color:var(--text-dim);color:var(--text)}.btn-modal-confirm{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-bg-low);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--accent2);cursor:pointer;padding:.45rem 1rem;font-family:Cinzel,serif;font-size:.75rem;transition:background .2s}.btn-modal-confirm:hover{background:var(--accent-bg-mid);color:var(--text)}.stats-builder{margin:16px 0}.stats-class-hint{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.hint-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-family:Cinzel,serif;font-size:11px}.hint-stat{color:var(--gold);background:var(--gold-bg-low);border:1px solid var(--gold2);border-radius:var(--radius-sm);padding:2px 7px;font-family:Cinzel,serif;font-size:11px;font-weight:700}.stats-method-tabs{gap:8px;margin-bottom:16px;display:flex}.stats-method-tab{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);text-transform:uppercase;cursor:pointer;flex:1;padding:10px 8px;font-family:Cinzel,serif;font-size:11px;transition:all .2s}.stats-method-tab:hover{border-color:var(--accent);color:var(--text)}.stats-method-tab.active{background:var(--accent-bg-low);border-color:var(--accent);color:var(--accent2)}.stats-grid{grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:16px;display:grid}.stat-box{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:8px 4px}.stat-box .stat-label{text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;font-family:Cinzel,serif;font-size:10px}.stat-box .stat-value{color:var(--gold);margin-bottom:4px;font-size:20px;font-weight:700}.stat-box .stat-mod{color:var(--accent2);font-size:12px}.stat-box .stat-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;margin:4px auto 0;font-size:14px;display:flex}.stat-box .stat-btn:hover{border-color:var(--accent);background:var(--accent-bg-low)}.stat-box .stat-btn:disabled{opacity:.3;cursor:not-allowed}.stat-box.min-stat{border-color:var(--color-warning)}.stat-box.max-stat{border-color:var(--accent)}.stats-points-remaining{text-align:center;color:var(--text-dim);background:var(--bg-card);border-radius:var(--radius-sm);padding:8px;font-family:Cinzel,serif;font-size:12px}.stats-points-remaining.low{color:var(--color-warning)}.stats-points-remaining.ok{color:var(--color-safe)}.stats-roll-result{justify-content:center;gap:12px;margin:12px 0;display:flex}.stats-roll-result .rolled-stat{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;min-width:50px;padding:8px}.stats-roll-result .rolled-stat .rolled-label{color:var(--text-muted);text-transform:uppercase;font-family:Cinzel,serif;font-size:9px}.asi-grid{grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:16px;display:grid}.asi-stat-box{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:8px 4px}.asi-stat-box .stat-label{text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;font-family:Cinzel,serif;font-size:10px}.asi-val{color:var(--gold);margin-bottom:2px;font-size:20px;font-weight:700}.asi-boost{color:var(--color-safe);min-height:16px;font-size:12px;font-weight:700}.asi-btn-row{justify-content:center;gap:4px;margin-top:4px;display:flex}.asi-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;font-size:16px;display:flex}.asi-btn:hover{border-color:var(--accent);background:var(--accent-bg-low)}.asi-remaining{text-align:center;color:var(--text-dim);background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:8px;padding:8px;font-family:Cinzel,serif;font-size:12px}@media (width<=660px){.asi-grid{grid-template-columns:repeat(3,1fr)}}.feat-or-asi-tabs{gap:6px;margin-bottom:12px;display:flex}.feat-tab{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;letter-spacing:.5px;flex:1;padding:8px 12px;font-family:Cinzel,serif;font-size:12px;transition:all .2s}.feat-tab:hover{border-color:var(--accent2);color:var(--text)}.feat-tab.active{background:var(--accent-bg-low);border-color:var(--accent);color:var(--accent2)}.feat-tab-panel{margin-top:4px}.feat-picker-grid{flex-direction:column;gap:6px;max-height:320px;margin-bottom:10px;display:flex;overflow-y:auto}.feat-card{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:10px 12px;transition:all .2s}.feat-card:hover{border-color:var(--accent2);background:var(--accent-bg-low)}.feat-card.selected{border-color:var(--gold);background:var(--gold-bg-low)}.feat-card-name{color:var(--text);align-items:center;gap:6px;margin-bottom:4px;font-family:Cinzel,serif;font-size:13px;display:flex}.feat-card.selected .feat-card-name{color:var(--gold2)}.feat-card-badge{text-transform:uppercase;letter-spacing:1px;vertical-align:middle;background:var(--bg-card);border:1px solid;border-color:var(--border);color:var(--text-muted);border-radius:999px;padding:1px 6px;font-family:Cinzel,serif;font-size:9px}.feat-card-desc{color:var(--text-muted);font-family:Crimson Text,serif;font-size:13px;line-height:1.4}.feat-sub-choices{margin-top:8px}.stats-roll-result .rolled-stat .rolled-value{color:var(--gold);font-size:18px;font-weight:700}.stats-roll-result .rolled-stat.assigned{opacity:.4}.stats-roll-result .rolled-stat.assigned .rolled-value{text-decoration:line-through}.stats-roll-result .rolled-stat.dragging{opacity:.5}.stats-roll-result .rolled-stat{cursor:grab}.stats-roll-result .rolled-stat:active{cursor:grabbing}.stat-box.drop-target{transition:all .2s}.stat-box.drop-target.drag-over{border-color:var(--accent);background:var(--accent-bg-low);transform:scale(1.05)}.stats-roll-select{text-align:center;margin:12px 0}.stats-roll-select select{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 12px;font-family:Crimson Text,serif}.stats-assign-instructions{text-align:center;color:var(--text-muted);margin-bottom:12px;font-size:12px}.stats-array-display{flex-wrap:wrap;justify-content:center;gap:8px;margin:12px 0;display:flex}.stats-array-value{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--gold);cursor:pointer;padding:8px 12px;font-family:Cinzel,serif;font-size:14px;transition:all .2s}.stats-array-value:hover{border-color:var(--accent)}.stats-array-value.selected{background:var(--accent-bg-low);border-color:var(--accent);color:var(--accent2)}.stats-array-value.assigned{opacity:.3}.stat-array-input:focus{outline:none;border-color:var(--accent)!important}.stat-array-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stat-array-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.libre-stat-input{box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--gold);text-align:center;-moz-appearance:textfield;margin:4px 0;padding:4px 2px;font-size:20px;font-weight:700}.libre-stat-input:focus{border-color:var(--accent);outline:none}.libre-stat-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.libre-stat-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stat-array-input{-moz-appearance:textfield}.origin-stats-bar{margin:16px 0 8px}.origin-stats-title{text-transform:uppercase;color:var(--gold);text-align:center;letter-spacing:1px;margin-bottom:10px;font-family:Cinzel,serif;font-size:12px}.origin-stats-pts{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-left:8px;font-family:Crimson Text,serif;font-size:13px}.origin-stats-pts.ok{color:var(--color-safe)}.origin-stats-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.origin-stat-box{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:6px 2px;position:relative}.origin-stat-box.eligible{border-color:var(--accent)}.origin-stat-label{text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;font-family:Cinzel,serif;font-size:9px}.origin-stat-value{color:var(--text-dim);font-size:18px;font-weight:700}.origin-stat-value.boosted{color:var(--gold)}.origin-stat-bonus{color:var(--accent2);margin-top:1px;font-family:Cinzel,serif;font-size:10px}.origin-stat-btns{justify-content:center;gap:4px;margin-top:4px;display:flex}.origin-stat-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:22px;height:22px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:14px;transition:all .2s;display:flex}.origin-stat-btn:hover:not([disabled]){border-color:var(--accent);background:var(--accent-bg-low)}.origin-stat-btn:disabled{opacity:.3;cursor:not-allowed}@media (width<=660px){.char-card{flex-direction:row;align-items:center;gap:.75rem;padding:.75rem 1rem}.char-card-avatar,.char-card-avatar-img{width:42px;height:42px}.char-card-avatar-img.char-card-avatar-fullbody{width:48px;height:66px}.char-card-body{flex-flow:column wrap;flex:1;align-items:flex-start;gap:.3rem;min-width:0}.char-card-name{font-size:.9rem}.char-card-meta{font-size:.8rem}.char-card-date{font-size:.7rem}.char-card-actions{gap:4px}.char-card-actions button,.char-card-actions a{padding:4px 8px;font-size:.65rem}}@media (width<=400px){.char-card-body{flex-direction:column;align-items:flex-start}.char-card-actions{justify-content:flex-start}}.beast-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin-bottom:8px;display:grid}.beast-card{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;background:var(--bg-card2);padding:8px 10px;transition:all .2s}.beast-card:hover{border-color:var(--accent2);background:var(--accent-bg-low)}.beast-card.active{border-color:var(--accent);background:var(--accent-bg-mid)}.beast-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.beast-name{color:var(--accent3);font-family:Cinzel,serif;font-size:12px;font-weight:700}.beast-cr{color:var(--gold2);background:var(--gold-bg-low);border:1px solid var(--gold);border-radius:3px;padding:1px 6px;font-family:Cinzel,serif;font-size:10px}.beast-stats-row{color:var(--text-dim);gap:8px;font-size:11px;display:flex}.beast-tooltip{z-index:1000;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-lg);flex-direction:column;gap:8px;width:320px;max-width:calc(100vw - 16px);padding:14px 16px;display:none;position:absolute;box-shadow:0 8px 32px #00000080}.beast-tooltip.open{display:flex}.beast-stats-grid{text-align:center;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:8px;display:grid}.beast-stats-grid>div{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:4px 2px;font-size:11px}.beast-stats-grid .stat-label{color:var(--gold2);margin-bottom:2px;font-family:Cinzel,serif;font-size:9px;display:block}.beast-info{color:var(--text-dim);font-size:12px;line-height:1.5}.beast-trait{margin-top:4px}.beast-attack{color:var(--text);margin-top:3px}.beast-card.transformed{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal)}.beast-card.transformed:hover{background:var(--bg-card2)}.beast-transform-btn{letter-spacing:.5px;text-transform:uppercase;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-muted);cursor:pointer;margin-top:6px;padding:3px 0;font-family:Cinzel,serif;font-size:9px;transition:all .15s;display:block}.beast-transform-btn:hover{border-color:var(--teal);color:var(--teal)}.beast-transform-btn.active{border-color:var(--blood);color:var(--blood2);background:var(--blood-bg-low)}.wild-shape-active-banner{border:1px solid var(--teal);border-radius:var(--radius-md);color:var(--teal);letter-spacing:.5px;background:#0d94881f;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;padding:8px 12px;font-family:Cinzel,serif;font-size:11px;display:flex}.wsa-name{color:var(--text);font-family:Cinzel,serif;font-size:13px;font-weight:700}.wsa-stats{color:var(--text-dim);font-family:Crimson Text,serif;font-size:12px}.wsa-quit-btn{background:var(--blood-bg-low);border:1px solid var(--blood);color:var(--blood2);letter-spacing:.5px;text-transform:uppercase;border-radius:var(--radius-sm);cursor:pointer;margin-left:auto;padding:3px 10px;font-family:Cinzel,serif;font-size:9px;transition:all .15s}.wsa-quit-btn:hover{background:var(--blood-bg-mid)}.infusion-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-top:8px;display:grid}.infusion-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;transition:border-color .2s}.infusion-card:hover{border-color:var(--accent2)}.infusion-name{color:var(--gold);margin-bottom:4px;font-family:Cinzel,serif;font-size:12px;font-weight:600}.infusion-desc{color:var(--text-dim);font-size:12px;line-height:1.5}.sheet-navbar{z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);border-right:none;flex-direction:column;gap:2px;padding:8px 6px;display:flex;position:fixed;top:50%;left:calc(50vw - 550px);transform:translateY(-50%);box-shadow:-4px 0 20px #00000059}.snav-item{border-radius:var(--radius-md);width:52px;height:46px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:3px;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.snav-icon{font-size:16px;line-height:1}.snav-label{text-transform:uppercase;letter-spacing:.5px;font-family:Cinzel,serif;font-size:8px;line-height:1}.snav-item:hover{background:var(--accent-bg-low);color:var(--accent2)}.snav-item:after{content:attr(data-label);white-space:nowrap;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);pointer-events:none;opacity:0;z-index:60;padding:5px 12px;font-family:Cinzel,serif;font-size:11px;transition:opacity .12s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);box-shadow:0 2px 10px #0006}.snav-item:hover:after{opacity:1}.snav-item.active{background:var(--accent-bg-low);color:var(--accent2)}.snav-item.active .snav-icon{text-shadow:0 0 10px var(--accent)}.chat-bubble{background:var(--accent);border:2px solid var(--accent2);color:#fff;cursor:pointer;z-index:600;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #8000ff4d}.chat-bubble:hover{transform:scale(1.1);box-shadow:0 6px 30px #8000ff73}.chat-panel{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-xl);z-index:600;flex-direction:column;width:380px;max-height:520px;display:flex;position:fixed;bottom:88px;right:24px;overflow:hidden;box-shadow:0 8px 40px #00000080}.chat-panel.hidden{display:none}.chat-header{background:var(--bg-card2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-title{color:var(--gold);font-family:Cinzel,serif;font-size:14px}.chat-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.chat-close:hover{color:var(--text)}.chat-messages{flex-direction:column;flex:1;gap:10px;max-height:380px;padding:12px;display:flex;overflow-y:auto}.chat-msg{border-radius:var(--radius-md);word-break:break-word;max-width:90%;padding:8px 12px;font-family:Crimson Text,serif;font-size:14px;line-height:1.5}.chat-msg-user{background:var(--accent-bg-mid);color:var(--text);border:1px solid var(--accent);align-self:flex-end}.chat-msg-bot{background:var(--bg-card2);color:var(--text);border:1px solid var(--border);align-self:flex-start}.chat-input-row{border-top:1px solid var(--border);background:var(--bg-card2);gap:8px;padding:10px 12px;display:flex}.chat-input{background:var(--bg-mid);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);outline:none;flex:1;padding:8px 12px;font-family:Crimson Text,serif;font-size:14px}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.chat-send{background:var(--accent);border-radius:var(--radius-md);color:#fff;cursor:pointer;border:none;padding:8px 14px;font-size:16px;transition:background .2s}.chat-send:hover{background:var(--accent2)}.chat-loading{gap:4px;padding:4px 0;display:flex}.chat-loading span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.2s infinite chatBounce}.chat-loading span:nth-child(2){animation-delay:.2s}.chat-loading span:nth-child(3){animation-delay:.4s}@keyframes chatBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}[data-theme=parchemin] .chat-bubble{box-shadow:0 4px 20px #b48c504d}[data-theme=parchemin] .chat-bubble:hover{box-shadow:0 6px 30px #b48c5073}[data-theme=parchemin] .chat-panel{background:var(--bg-card);border-color:var(--border2)}@media (width<=660px){.chat-bubble{width:44px;height:44px;font-size:18px;bottom:70px;right:12px}.chat-panel{border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:70vh;bottom:0;left:0;right:0}}@media (width<=1059px){.sheet-navbar{display:none}}@media (width<=660px){.sheet-navbar{border:none;border-top:1px solid var(--border);border-right:1px solid var(--border);width:100%;padding:4px 2px env(safe-area-inset-bottom,4px);z-index:80;border-radius:0;flex-direction:row;justify-content:space-around;gap:0;display:flex;position:fixed;inset:auto 0 0;transform:none;box-shadow:0 -4px 20px #00000073}.snav-item{border-radius:var(--radius-sm);flex:1;width:auto;height:52px}.snav-item:after{display:none}.snav-icon{font-size:15px}.snav-label{letter-spacing:0;font-size:7px}.gear-fixed{background:var(--bg-deep);border-bottom:1px solid var(--border);z-index:500;justify-content:flex-end;align-items:center;height:44px;padding:0 10px;display:flex;position:fixed;top:0;left:0;right:0}.btn-settings-gear{background:0 0;border:none;width:32px;height:32px;font-size:16px}.btn-back-fixed,.btn-back-home.btn-back-fixed{letter-spacing:1px;z-index:501;background:0 0;border:none;border-radius:0;align-items:center;height:44px;padding:0 14px;font-size:12px;display:flex;position:fixed;top:0;left:0}[data-theme=parchemin] .gear-fixed{background:#e8d5ae;border-bottom-color:#64461e40}}.avatar-editor{flex-direction:column;align-items:center;gap:16px;display:flex}.avatar-editor-preview{justify-content:center;display:flex}.avatar-canvas-preview{border:3px solid var(--gold);width:180px;height:180px;box-shadow:0 0 20px var(--glow-gold,#d4a85340), inset 0 0 12px #0000004d;border-radius:50%}.avatar-editor-preview{justify-content:center;align-items:center;height:310px;display:flex;position:relative}.avatar-img-preview.avatar-fullbody{border-radius:var(--radius-lg,8px);object-fit:contain;object-position:bottom;width:auto;max-width:220px;height:100%;max-height:290px}.avatar-editor-controls{flex-direction:column;gap:12px;width:100%;display:flex}.avatar-row{flex-direction:column;gap:6px;margin-bottom:15px;display:flex}.avatar-row-label{font-family:var(--font-heading,"Cinzel", serif);letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);font-size:11px;font-weight:600}.avatar-swatches{flex-wrap:wrap;gap:6px;display:flex}.avatar-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;padding:0;transition:all .2s;box-shadow:inset 0 1px 2px #0000004d,0 1px 2px #0003}.avatar-swatch:hover{border-color:var(--text-dim);transform:scale(1.15)}.avatar-swatch.active{border-color:var(--gold);box-shadow:0 0 8px var(--glow-gold,#d4a85366), inset 0 1px 2px #0000004d;transform:scale(1.1)}.avatar-toggles{flex-wrap:wrap;gap:5px;display:flex}.avatar-toggle{font-family:var(--font-body,"Crimson Text", serif);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card2);color:var(--text-dim);cursor:pointer;letter-spacing:.3px;padding:5px 12px;font-size:13px;transition:all .2s}.avatar-toggle:hover{border-color:var(--accent3,#c084fc);color:var(--text);background:var(--accent-bg-low,#7c3aed14)}.avatar-toggle.active{background:var(--accent-bg-mid,#7c3aed26);border-color:var(--accent2,#a855f7);color:var(--text);box-shadow:0 0 6px var(--glow-purple,#7c3aed33);font-weight:600}[data-theme=parchemin] .avatar-canvas-preview{border-color:var(--gold);box-shadow:0 0 16px #78551440,inset 0 0 10px #3c280a26}[data-theme=parchemin] .avatar-toggle{color:var(--text-muted);background:#dcc8a066;border-color:#64461e4d}[data-theme=parchemin] .avatar-toggle:hover{border-color:var(--accent2);color:var(--text);background:#5a2d8214}[data-theme=parchemin] .avatar-toggle.active{border-color:var(--accent);color:var(--text);background:#5a2d821f;box-shadow:0 0 6px #5a2d8226}[data-theme=parchemin] .avatar-swatch{box-shadow:inset 0 1px 2px #3c280a40,0 1px 2px #3c280a26}[data-theme=parchemin] .avatar-swatch.active{border-color:var(--gold);box-shadow:0 0 6px #78551459,inset 0 1px 2px #3c280a40}.avatar-img-preview{border:3px solid var(--gold);width:180px;height:180px;box-shadow:0 0 20px var(--glow-gold,#d4a85340), inset 0 0 12px #0000004d;object-fit:cover;border-radius:50%}[data-theme=parchemin] .avatar-img-preview{border-color:var(--gold);box-shadow:0 0 16px #78551440,inset 0 0 10px #3c280a26}.avatar-mode-row{margin-bottom:4px}.avatar-upload-zone{border:2px dashed var(--border2,#3d3060);border-radius:var(--radius-lg);background:var(--bg-card2,#0e1520);cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px 16px;transition:all .25s;display:flex}.avatar-upload-zone:hover,.avatar-upload-zone.dragover{border-color:var(--accent2,#a855f7);background:var(--accent-bg-low,#7c3aed14)}.avatar-upload-zone.dragover{box-shadow:0 0 12px var(--glow-purple,#7c3aed4d);transform:scale(1.02)}.avatar-upload-zone.uploading{opacity:.6;pointer-events:none}.avatar-upload-zone.uploading .avatar-upload-text:after{content:"...";animation:1.2s steps(3,end) infinite dots}@keyframes dots{0%{content:"."}33%{content:".."}66%{content:"..."}}.avatar-file-input{display:none}.avatar-upload-icon{font-size:28px;line-height:1}.avatar-upload-text{font-family:var(--font-body,"Crimson Text", serif);color:var(--text-dim);letter-spacing:.3px;font-size:13px}.avatar-upload-zone:hover .avatar-upload-text{color:var(--text)}[data-theme=parchemin] .avatar-upload-zone{background:#dcc8a04d;border-color:#64461e59}[data-theme=parchemin] .avatar-upload-zone:hover,[data-theme=parchemin] .avatar-upload-zone.dragover{border-color:var(--accent2);background:#5a2d820f}.avatar-ai-controls{flex-direction:column;gap:10px;display:flex}.avatar-ai-hint{font-family:var(--font-body,"Crimson Text", serif);color:var(--text-muted);margin-top:-6px;font-size:12px;font-style:italic}.avatar-ai-token{width:100%;font-family:var(--font-body,"Crimson Text", serif);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-deep);color:var(--text);padding:7px 10px;font-size:13px;transition:border-color .2s}.avatar-ai-token:focus{border-color:var(--accent2,#a855f7);box-shadow:0 0 6px var(--glow-purple,#7c3aed33);outline:none}.avatar-ai-prompt{width:100%;font-family:var(--font-body,"Crimson Text", serif);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-deep);color:var(--text);resize:vertical;min-height:70px;padding:8px 10px;font-size:12.5px;line-height:1.5;transition:border-color .2s}.avatar-ai-prompt:focus{border-color:var(--accent2,#a855f7);box-shadow:0 0 6px var(--glow-purple,#7c3aed33);outline:none}.avatar-ai-reset-btn{font-family:var(--font-body,"Crimson Text", serif);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);cursor:pointer;background:0 0;align-self:flex-start;padding:3px 10px;font-size:12px;transition:all .2s}.avatar-ai-reset-btn:hover{border-color:var(--accent3);color:var(--text)}.avatar-slider-wrap{flex:1;align-items:center;gap:8px;display:flex}.avatar-slider{accent-color:var(--accent);cursor:pointer;flex:1;height:6px}.avatar-slider-value{color:var(--text-dim);text-align:right;min-width:52px;font-family:Crimson Text,serif;font-size:13px}.avatar-ai-seed-row{align-items:center;gap:8px;display:flex}.avatar-ai-seed-row .avatar-row-label{min-width:36px}.avatar-ai-seed{font-family:var(--font-body,"Crimson Text", serif);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-deep);color:var(--text);flex:1;width:100px;padding:5px 8px;font-size:13px}.avatar-ai-seed:focus{border-color:var(--accent2);outline:none}.avatar-ai-seed-random{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card2);cursor:pointer;padding:4px 8px;font-size:16px;line-height:1;transition:all .2s}.avatar-ai-seed-random:hover{border-color:var(--gold);transform:scale(1.1)}.avatar-ai-generate-btn{width:100%;font-family:var(--font-heading,"Cinzel", serif);letter-spacing:1px;text-transform:uppercase;border:1px solid var(--accent2,#a855f7);border-radius:var(--radius-md);background:var(--accent-bg-mid,#7c3aed26);color:var(--text);cursor:pointer;padding:10px 16px;font-size:13px;font-weight:600;transition:all .25s}.avatar-ai-generate-btn:hover:not(:disabled){background:var(--accent-bg-high,#7c3aed40);box-shadow:0 0 12px var(--glow-purple,#7c3aed4d);transform:translateY(-1px)}.avatar-ai-generate-btn:disabled{opacity:.6;cursor:wait}.avatar-ai-spinner{border:2px solid var(--text-dim);border-top-color:var(--accent2);vertical-align:middle;border-radius:50%;width:14px;height:14px;margin-right:6px;animation:.8s linear infinite avatar-spin;display:inline-block}@keyframes avatar-spin{to{transform:rotate(360deg)}}.avatar-ai-status{font-family:var(--font-body,"Crimson Text", serif);min-height:18px;color:var(--text-muted);text-align:center;font-size:12px}.avatar-ai-status.success{color:var(--color-safe,#2dd4bf)}.avatar-ai-status.error{color:var(--color-warning,#f87171)}[data-theme=parchemin] .avatar-ai-token,[data-theme=parchemin] .avatar-ai-prompt,[data-theme=parchemin] .avatar-ai-seed{color:var(--text);background:#f0e6d280;border-color:#64461e4d}[data-theme=parchemin] .avatar-ai-token:focus,[data-theme=parchemin] .avatar-ai-prompt:focus,[data-theme=parchemin] .avatar-ai-seed:focus{border-color:var(--accent2);box-shadow:0 0 6px #5a2d8226}[data-theme=parchemin] .avatar-ai-generate-btn{border-color:var(--accent);background:#5a2d821a}[data-theme=parchemin] .avatar-ai-generate-btn:hover:not(:disabled){background:#5a2d822e;box-shadow:0 0 10px #5a2d8233}[data-theme=parchemin] .avatar-ai-seed-random{background:#dcc8a066;border-color:#64461e4d}.char-card-avatar{border-radius:50%;flex-shrink:0;width:48px;height:48px}.char-card-avatar-img{object-fit:cover;border-radius:50%;width:48px;height:48px}.char-card-avatar-img.char-card-avatar-fullbody{border-radius:var(--radius-sm,4px);object-position:top;width:52px;height:72px}.avatar-zoom-overlay{z-index:9999;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;animation:.2s avatarZoomFadeIn;display:none;position:fixed;inset:0}.avatar-zoom-overlay.open{display:flex}@keyframes avatarZoomFadeIn{0%{opacity:0}to{opacity:1}}.avatar-zoom-img{border-radius:var(--radius-lg,8px);border:3px solid var(--gold);object-fit:contain;max-width:90vw;max-height:85vh;animation:.25s avatarZoomScaleIn;box-shadow:0 0 40px #d4a85359,0 0 80px #0009}@keyframes avatarZoomScaleIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.avatar-zoom-close{color:var(--gold);cursor:pointer;opacity:.7;z-index:10000;background:0 0;border:none;font-size:28px;transition:opacity .2s;position:absolute;top:16px;right:20px}.avatar-zoom-close:hover{opacity:1}.avatar-zoom-edit{border:1px solid var(--gold);color:var(--gold);border-radius:var(--radius-md,6px);cursor:pointer;opacity:.8;z-index:10000;background:#00000080;padding:6px 14px;font-family:Cinzel,serif;font-size:14px;transition:opacity .2s,background .2s;position:absolute;top:16px;left:20px}.avatar-zoom-edit:hover{opacity:1;background:#000000b3}.header-avatar,.char-card-avatar-img{cursor:pointer}.landing-page{background:radial-gradient(ellipse at 30% 0%, #7c3aed1f 0%, transparent 50%), radial-gradient(ellipse at 70% 100%, #8b00001a 0%, transparent 50%), var(--bg-deep);padding:0;overflow-x:hidden}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(12px);background:#0a0d14d9;border-bottom:1px solid #7c3aed26;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;padding:0 24px;display:flex}.landing-nav-logo{color:var(--gold);letter-spacing:2px;font-family:Cinzel Decorative,serif;font-size:1.3rem}.landing-nav-actions{align-items:center;gap:12px;display:flex}.landing-nav-btn{border:1px solid var(--accent);color:var(--accent2);border-radius:var(--radius-md);cursor:pointer;letter-spacing:1px;background:0 0;padding:8px 20px;font-family:Cinzel,serif;font-size:.8rem;transition:all .3s}.landing-nav-btn:hover{background:var(--accent);color:#fff;box-shadow:0 0 20px var(--glow-purple)}.landing-hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:80px 24px 40px;display:flex;position:relative}.landing-hero-bg{pointer-events:none;background:radial-gradient(circle at 50% 40%,#7c3aed14 0%,#0000 60%),radial-gradient(circle at 50% 60%,#d4a8530d 0%,#0000 50%);position:absolute;inset:0}.landing-hero-content{z-index:1;position:relative}.landing-hero-title{color:var(--gold);text-shadow:0 0 40px #d4a8534d,0 0 80px #d4a8531a;letter-spacing:4px;margin-bottom:20px;font-family:Cinzel Decorative,serif;font-size:clamp(2.5rem,8vw,5rem);font-weight:700;animation:1.2s ease-out heroFadeIn}.landing-hero-tagline{color:var(--text-dim);margin-bottom:40px;font-family:Crimson Text,serif;font-size:clamp(1.1rem,3vw,1.5rem);line-height:1.7;animation:1.2s ease-out .2s both heroFadeIn}.landing-hero-actions{flex-wrap:wrap;justify-content:center;gap:16px;animation:1.2s ease-out .4s both heroFadeIn;display:flex}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-hero-scroll-hint{color:var(--text-muted);font-size:1.5rem;animation:2s infinite bounce;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(8px)}}.landing-btn-primary{background:linear-gradient(135deg, var(--accent) 0%, #9333ea 100%);color:#fff;border-radius:var(--radius-lg);cursor:pointer;letter-spacing:1px;border:none;padding:14px 36px;font-family:Cinzel,serif;font-size:.95rem;transition:all .3s;box-shadow:0 4px 20px #7c3aed4d}.landing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #7c3aed80}.landing-btn-secondary{color:var(--text-dim);border:1px solid var(--border2);border-radius:var(--radius-lg);cursor:pointer;letter-spacing:1px;background:0 0;padding:14px 36px;font-family:Cinzel,serif;font-size:.95rem;text-decoration:none;transition:all .3s}.landing-btn-secondary:hover{border-color:var(--gold);color:var(--gold)}.landing-section{max-width:1100px;margin:0 auto;padding:80px 24px}.landing-section-alt{position:relative}.landing-section-alt:before{content:"";z-index:-1;background:#7c3aed08;border-top:1px solid #7c3aed14;border-bottom:1px solid #7c3aed14;position:absolute;inset:0 -50vw}.landing-section-title{color:var(--gold);text-align:center;letter-spacing:2px;margin-bottom:50px;font-family:Cinzel Decorative,serif;font-size:clamp(1.5rem,4vw,2.2rem)}.landing-features-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.landing-feature-card{border:1px solid var(--border);border-radius:var(--radius-xl);opacity:0;background:#13182899;padding:32px 28px;transition:all .4s;transform:translateY(30px)}.landing-feature-card.visible{opacity:1;transform:translateY(0)}.landing-feature-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 40px #7c3aed26}.landing-feature-card.visible:hover{transform:translateY(-4px)}.landing-feature-icon{margin-bottom:16px;font-size:2.5rem}.landing-feature-name{color:var(--gold2);letter-spacing:1px;margin-bottom:10px;font-family:Cinzel,serif;font-size:1.1rem}.landing-feature-desc{color:var(--text-dim);font-family:Crimson Text,serif;font-size:1rem;line-height:1.6}.landing-stats-grid{text-align:center;grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.landing-stat{opacity:0;flex-direction:column;gap:8px;transition:all .6s;display:flex;transform:translateY(20px)}.landing-stat.visible{opacity:1;transform:translateY(0)}.landing-stat-number{color:var(--accent2);text-shadow:0 0 30px #a855f74d;font-family:Cinzel Decorative,serif;font-size:clamp(2rem,5vw,3rem);font-weight:700}.landing-stat-label{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-family:Cinzel,serif;font-size:.85rem}.landing-patchnotes{max-width:700px;max-height:500px;margin:0 auto;padding-right:8px;overflow-y:auto}.landing-patchnotes::-webkit-scrollbar{width:6px}.landing-patchnotes::-webkit-scrollbar-track{background:0 0}.landing-patchnotes::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.landing-cta{text-align:center;padding:100px 24px}.landing-cta-title{color:var(--gold);letter-spacing:2px;margin-bottom:16px;font-family:Cinzel Decorative,serif;font-size:clamp(1.5rem,4vw,2.2rem)}.landing-cta-desc{color:var(--text-dim);margin-bottom:32px;font-family:Crimson Text,serif;font-size:1.15rem}.landing-footer{border-top:1px solid var(--border);padding:24px}.landing-footer-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;display:flex}.landing-footer-brand{color:var(--text-muted);letter-spacing:1px;font-family:Cinzel,serif;font-size:.9rem}.landing-footer-version{color:var(--text-muted);opacity:.5;font-family:Crimson Text,serif;font-size:.8rem}.login-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:40px 36px;animation:.3s modalSlide;position:relative;box-shadow:0 20px 60px #00000080}@keyframes modalSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.8rem;line-height:1;transition:color .2s;position:absolute;top:12px;right:16px}.login-modal-close:hover{color:var(--text)}.login-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex}.login-tab{color:var(--text-muted);cursor:pointer;letter-spacing:1px;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-family:Cinzel,serif;font-size:.85rem;transition:all .3s}.login-tab.active{color:var(--accent2);border-bottom-color:var(--accent)}.login-tab:hover:not(.active){color:var(--text-dim)}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;font-family:Cinzel,serif;font-size:.75rem}.login-input{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);padding:12px 14px;font-family:Crimson Text,serif;font-size:1rem;transition:border-color .3s}.login-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #7c3aed26}.login-input::placeholder{color:var(--text-muted)}.login-submit{background:linear-gradient(135deg, var(--accent) 0%, #9333ea 100%);color:#fff;border-radius:var(--radius-md);cursor:pointer;letter-spacing:1px;border:none;margin-top:4px;padding:12px;font-family:Cinzel,serif;font-size:.9rem;transition:all .3s}.login-submit:hover{transform:translateY(-1px);box-shadow:0 4px 20px #7c3aed66}.login-msg{min-height:1.2em;font-family:Crimson Text,serif;font-size:.9rem}.login-msg--error{color:var(--red-soft)}.login-msg--ok{color:var(--teal)}.login-divider{color:var(--text-muted);align-items:center;gap:16px;margin:20px 0;font-family:Crimson Text,serif;font-size:.9rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-oauth{flex-direction:column;gap:10px;display:flex}.login-oauth-btn{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-deep);color:var(--text);cursor:pointer;justify-content:center;align-items:center;gap:10px;padding:11px 16px;font-family:Crimson Text,serif;font-size:.95rem;text-decoration:none;transition:all .3s;display:flex}.login-oauth-btn:hover{border-color:var(--text-muted);background:#ffffff08}.login-oauth-discord:hover{border-color:#5865f2}.login-oauth-google:hover{border-color:#4285f4}@media (width<=768px){.landing-features-grid{grid-template-columns:1fr}.landing-stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}.landing-hero{padding:100px 20px 60px}.landing-section{padding:60px 20px}}@media (width<=480px){.landing-stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}.login-modal{margin:16px;padding:28px 20px}.landing-hero-actions{flex-direction:column;align-items:center}.landing-btn-primary,.landing-btn-secondary{text-align:center;width:100%}}.app-header{z-index:800;-webkit-backdrop-filter:blur(14px);background:#0a0d14eb;border-bottom:1px solid #7c3aed1f;height:52px;position:fixed;top:0;left:0;right:0}.app-header-inner{align-items:center;gap:16px;max-width:1200px;height:100%;margin:0 auto;padding:0 20px;display:flex}.app-header-logo{color:var(--gold);cursor:pointer;letter-spacing:2px;text-shadow:0 0 20px #d4a85326;background:0 0;border:none;flex-shrink:0;font-family:Cinzel Decorative,serif;font-size:1.1rem;font-weight:700;transition:color .2s,text-shadow .2s}.app-header-logo:hover{color:var(--gold2);text-shadow:0 0 30px #d4a8534d}.app-breadcrumb{flex:1;align-items:center;gap:0;min-width:0;display:flex}.app-breadcrumb-item{align-items:center;gap:0;min-width:0;display:flex}.app-breadcrumb-sep{color:var(--gold);opacity:.5;-webkit-user-select:none;user-select:none;margin:0 10px;font-size:1rem}.app-breadcrumb-link{color:var(--text-dim);cursor:pointer;letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;max-width:160px;padding:4px 0;font-family:Cinzel,serif;font-size:.78rem;transition:color .2s;overflow:hidden}.app-breadcrumb-link:hover{color:var(--gold2)}.app-breadcrumb-current{color:var(--text);letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-family:Cinzel,serif;font-size:.78rem;overflow:hidden}.app-header-user{flex-shrink:0;align-items:center;gap:12px;display:flex}.app-header-username{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-family:Crimson Text,serif;font-size:.85rem;overflow:hidden}.app-header-logout{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 10px;font-family:Cinzel,serif;font-size:.65rem;transition:all .2s}.app-header-logout:hover{color:var(--blood2);border-color:var(--blood)}:is(body:has(.app-header) .sheet-container,body:has(.app-header) .home-container){padding-top:68px}@media (width<=660px){.app-header-inner{padding:0 12px}.app-header-logo{letter-spacing:1px;font-size:.9rem}.app-breadcrumb-link,.app-breadcrumb-current{max-width:100px;font-size:.7rem}.app-header-username{display:none}.app-header-logout{padding:3px 8px;font-size:.6rem}}.header-avatar-placeholder{background:var(--bg-card);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:2rem;display:flex}.class-features-section{margin-top:14px}.features-list{flex-direction:column;gap:12px;display:flex}.class-feature{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px}.feature-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.feature-name{color:var(--gold2);letter-spacing:.5px;font-family:Cinzel,serif;font-size:.8rem}.feature-rest{color:var(--text-muted);font-family:Crimson Text,serif;font-size:.75rem;font-style:italic}.pips-row{flex-wrap:wrap;gap:6px;display:flex}.hands-pool-control{justify-content:center;align-items:center;gap:8px;display:flex}.hands-pool-display{color:var(--gold);text-align:center;min-width:40px;font-family:Cinzel Decorative,serif;font-size:1.3rem}.spells-section{margin-top:14px}.spell-slots-list{flex-direction:column;gap:8px;display:flex}.spell-slot-row{align-items:center;gap:10px;display:flex}.spell-slot-label{color:var(--text-muted);min-width:30px;font-family:Cinzel,serif;font-size:.75rem}.divider{border:none;border-top:1px solid var(--border);margin:12px 0}.save-indicator{background:var(--accent);color:#fff;border-radius:var(--radius-md);opacity:.85;z-index:900;padding:8px 16px;font-family:Cinzel,serif;font-size:.75rem;animation:.2s fadeIn;position:fixed;bottom:16px;right:16px}
