:root {
  --g: #8bc34a; --g2: #b8e06a; --sun: #f0c040;
  --cream: #ede8d5; --muted: rgba(237,232,213,.58);
  --dim: rgba(237,232,213,.36); --faint: rgba(237,232,213,.18);
  --bg: #111309; --bg2: #14160d; --bg3: #191c11;
  --border: rgba(139,195,74,.11); --border2: rgba(139,195,74,.22);
  --red: #e05050; --r: 6px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--cream);font-family:'Nunito',sans-serif;font-size:15px;line-height:1.75;overflow-x:hidden}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:rgba(139,195,74,.25);border-radius:2px}
.topbar{position:fixed;top:0;left:0;right:0;z-index:300;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:rgba(14,15,9,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.tb-left{display:flex;align-items:center;gap:12px}
.tb-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.tb-logo-txt{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;color:var(--g)}
.tb-sep{width:1px;height:18px;background:var(--border2)}
.tb-book{font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.tb-right{display:flex;align-items:center;gap:6px}
.tb-btn{font-size:.76rem;font-weight:700;color:var(--dim);text-decoration:none;padding:5px 11px;border:1px solid var(--border);border-radius:var(--r);transition:color .14s,border-color .14s,background .14s}
.tb-btn:hover{color:var(--g);border-color:var(--border2);background:rgba(139,195,74,.04)}
.layout{display:flex;min-height:100vh;padding-top:52px}
.sidebar{width:244px;flex-shrink:0;position:sticky;top:52px;height:calc(100vh - 52px);overflow-y:auto;overflow-x:hidden;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column}
.sidebar::-webkit-scrollbar{width:2px}
.sb-search-wrap{padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0}
.sb-search{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);padding:7px 11px;font-family:'Nunito',sans-serif;font-size:.8rem;color:var(--cream);outline:none;transition:border-color .14s}
.sb-search::placeholder{color:var(--faint)}
.sb-search:focus{border-color:var(--border2)}
.sb-body{flex:1;padding:10px 0 20px}
.sb-group{font-size:.62rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding:10px 14px 4px}
.sb-item{display:flex;align-items:center;gap:7px;padding:7px 14px;font-size:.84rem;font-weight:600;color:var(--dim);cursor:pointer;border-left:2px solid transparent;border-radius:0 var(--r) var(--r) 0;transition:color .14s,background .14s,border-color .14s;user-select:none}
.sb-item:hover{color:rgba(237,232,213,.82);background:rgba(139,195,74,.05)}
.sb-item.active{color:var(--g);border-left-color:var(--g);background:rgba(139,195,74,.08);font-weight:800}
.sb-icon{width:13px;height:13px;flex-shrink:0;opacity:.55;color:currentColor}
.sb-item.active .sb-icon{opacity:.9}
.main{flex:1;min-width:0;padding:44px 56px 80px 52px;max-width:860px}
.page{display:none}
.page.active{display:block}
.page-bc{font-size:.67rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:10px;display:flex;align-items:center;gap:5px}
.page-title{font-family:'Fraunces',serif;font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:700;line-height:1.1;color:var(--cream);margin-bottom:8px}
.page-desc{font-size:.95rem;color:var(--dim);margin-bottom:32px;padding-bottom:26px;border-bottom:1px solid var(--border);line-height:1.6}
h2.dh{font-family:'Fraunces',serif;font-size:1.18rem;font-weight:700;color:var(--cream);margin:30px 0 13px;padding-top:26px;border-top:1px solid var(--border);display:flex;align-items:center;gap:9px}
h2.dh:first-of-type{border-top:none;padding-top:0;margin-top:0}
h2.dh::before{content:'';width:3px;height:1.1em;background:var(--g);flex-shrink:0;display:block;border-radius:2px}
h3.dh3{font-family:'Fraunces',serif;font-size:1rem;font-weight:700;color:rgba(237,232,213,.88);margin:20px 0 9px;display:flex;align-items:center;gap:7px}
h3.dh3::before{content:'';width:2px;height:1em;background:rgba(139,195,74,.45);flex-shrink:0;border-radius:1px}
p.dp{color:var(--muted);margin-bottom:11px;font-size:.93rem;line-height:1.78}
p.dp strong{color:var(--cream);font-weight:800}
p.dp a{color:var(--g);text-decoration:none}
p.dp a:hover{text-decoration:underline}
p.dp em{font-style:italic}
p.dp code{background:rgba(139,195,74,.09);border:1px solid rgba(139,195,74,.18);border-radius:4px;padding:1px 6px;font-family:'Courier New',monospace;font-size:.84rem;color:var(--g2)}
ul.du{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
ul.du li{display:flex;align-items:flex-start;gap:9px;font-size:.9rem;color:var(--muted);line-height:1.7}
ul.du li::before{content:'';width:4px;height:4px;background:var(--g);flex-shrink:0;margin-top:.68em;border-radius:50%}
ul.du li strong{color:var(--cream);font-weight:800}
ul.du li a{color:var(--g);text-decoration:none}
ul.du li a:hover{text-decoration:underline}
ul.du li code{background:rgba(139,195,74,.09);border:1px solid rgba(139,195,74,.18);border-radius:4px;padding:1px 6px;font-family:'Courier New',monospace;font-size:.84rem;color:var(--g2)}
ol.do{list-style:none;counter-reset:c;display:flex;flex-direction:column;gap:9px;margin-bottom:13px}
ol.do li{display:flex;align-items:flex-start;gap:11px;font-size:.9rem;color:var(--muted);line-height:1.7;counter-increment:c}
ol.do li::before{content:counter(c);min-width:20px;height:20px;background:rgba(139,195,74,.09);border:1px solid rgba(139,195,74,.2);border-radius:5px;color:var(--g);font-size:.69rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
ol.do li strong{color:var(--cream);font-weight:800}
.rules-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.rule-item{display:flex;align-items:flex-start;gap:11px;font-size:.9rem;color:var(--muted);line-height:1.7}
.rule-num{min-width:22px;height:22px;background:rgba(139,195,74,.1);border:1px solid rgba(139,195,74,.22);border-radius:5px;color:var(--g);font-size:.7rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.rule-item strong{color:var(--cream);font-weight:800}
.rule-sub{font-size:.85rem;color:var(--dim);margin-top:3px;display:block}
code.ic{background:rgba(139,195,74,.09);border:1px solid rgba(139,195,74,.18);border-radius:4px;padding:1px 6px;font-family:'Courier New',monospace;font-size:.84rem;color:var(--g2)}
.code-wrap{position:relative;margin:12px 0}
.code-wrap:hover .copy-btn{opacity:1}
.code-block{background:rgba(139,195,74,.06);border:1px solid rgba(139,195,74,.18);border-radius:var(--r);padding:13px 16px;font-family:'Courier New',monospace;font-size:.87rem;color:var(--g2);line-height:1.65;white-space:pre;overflow-x:auto}
.copy-btn{position:absolute;top:7px;right:8px;background:rgba(20,22,13,.88);border:1px solid rgba(139,195,74,.22);border-radius:5px;padding:3px 10px;font-family:'Nunito',sans-serif;font-size:.67rem;font-weight:900;letter-spacing:.06em;color:var(--g);cursor:pointer;text-transform:uppercase;transition:background .13s,opacity .15s;opacity:0;backdrop-filter:blur(4px)}
.copy-btn:hover{background:rgba(139,195,74,.15)}
.copy-btn.ok{background:rgba(139,195,74,.2);color:var(--g2)}
.hint{border-left:3px solid var(--g);background:rgba(139,195,74,.05);border-radius:0 var(--r) var(--r) 0;padding:11px 15px;margin:14px 0;display:flex;gap:10px;align-items:flex-start}
.hint.warn{border-left-color:var(--sun);background:rgba(240,192,64,.05)}
.hint.danger{border-left-color:var(--red);background:rgba(220,70,70,.05)}
.hint-ico{flex-shrink:0;margin-top:1px;color:var(--g)}
.hint.warn .hint-ico{color:var(--sun)}
.hint.danger .hint-ico{color:var(--red)}
.hint-ico svg{width:15px;height:15px}
.hint-body{font-size:.88rem;color:var(--muted);line-height:1.65}
.hint-body strong{color:var(--cream)}
.hint-body a{color:var(--g);text-decoration:none;cursor:pointer}
.hint-body a:hover{text-decoration:underline}
.info-tbl{width:100%;border-collapse:collapse;margin:13px 0;font-size:.88rem}
.info-tbl tr{border-bottom:1px solid var(--border)}
.info-tbl tr:last-child{border-bottom:none}
.info-tbl td{padding:8px 0;vertical-align:top}
.info-tbl td:first-child{color:var(--dim);font-weight:800;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;width:145px;padding-right:14px}
.info-tbl td code{background:rgba(139,195,74,.09);border:1px solid rgba(139,195,74,.16);border-radius:4px;padding:1px 6px;font-family:'Courier New',monospace;font-size:.83rem;color:var(--g2)}
.tag-tbl{width:100%;border-collapse:collapse;margin:13px 0;font-size:.88rem}
.tag-tbl th{text-align:left;font-size:.65rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:5px 0;border-bottom:1px solid var(--border)}
.tag-tbl tr{border-bottom:1px solid var(--border)}
.tag-tbl tr:last-child{border-bottom:none}
.tag-tbl td{padding:7px 0;color:var(--muted);vertical-align:top}
.tag-tbl td:first-child{width:110px;padding-right:14px}
.doc-img{display:block;max-width:100%;margin:14px 0;border:1px solid var(--border);border-radius:var(--r)}
.page-nav{display:flex;gap:10px;margin-top:44px;padding-top:22px;border-top:1px solid var(--border)}
.pnav-btn{flex:1;padding:12px 16px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;color:var(--dim);font-family:'Nunito',sans-serif;font-size:.82rem;font-weight:700;transition:border-color .14s,color .14s,background .14s;display:flex;flex-direction:column;gap:3px;text-decoration:none}
.pnav-btn:hover{border-color:var(--border2);color:var(--cream);background:rgba(139,195,74,.04)}
.pnav-btn.r{text-align:right}
.pnav-lbl{font-size:.63rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.pnav-title{color:var(--g)}
.pnav-empty{flex:1}
.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--dim);gap:16px}
.loading-spinner{width:32px;height:32px;border:2px solid rgba(139,195,74,.2);border-top-color:var(--g);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.gen-table{width:100%;border-collapse:collapse;margin:13px 0;font-size:.88rem}
.gen-table th{text-align:left;font-size:.65rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:6px 8px;border-bottom:1px solid var(--border)}
.gen-table tr{border-bottom:1px solid var(--border)}
.gen-table tr:last-child{border-bottom:none}
.gen-table td{padding:8px;color:var(--muted);vertical-align:top}
.gen-table td:first-child{color:var(--cream);font-weight:700}
hr.doc-hr{border:none;border-top:1px solid var(--border);margin:20px 0}
.rules-group{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.rule-row{display:flex;align-items:flex-start;gap:11px;font-size:.9rem;color:var(--muted);line-height:1.7}
.rule-row .rule-num{min-width:22px;height:22px;background:rgba(139,195,74,.1);border:1px solid rgba(139,195,74,.22);border-radius:5px;color:var(--g);font-size:.7rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.rule-row .rule-body{flex:1}
.rule-row .rule-sub{font-size:.85rem;color:var(--dim);margin-top:3px;display:block}
@media(max-width:860px){.sidebar{display:none}.main{padding:28px 20px 60px}}
@media(max-width:560px){.tb-right{display:none}}
