/* CV Encyclopedia v5 */
:root{--cv-green:#18291F;--cv-green-light:#1e3328;--cv-charcoal:#212323;--cv-offwhite:#F7F5F2;--cv-beige:#E5DED0;--cv-brass:#C9AB77;--cv-brass-warm:#D4BE96;--cv-white:#FFFFFF;--cv-font-serif:'Cormorant Garamond',serif;--cv-font-sans:'DM Sans',sans-serif;--header-height:72px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow-x:hidden;overflow-y:auto;background:var(--cv-green);color:var(--cv-beige);font-family:var(--cv-font-sans);font-weight:300;-webkit-font-smoothing:antialiased;line-height:1.6}
a{color:inherit;text-decoration:none;transition:color .3s}img{display:block;max-width:100%;height:auto}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}ul,ol{list-style:none}input{font:inherit;color:inherit}
::selection{background:var(--cv-brass);color:var(--cv-white)}
::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cv-green)}::-webkit-scrollbar-thumb{background:rgba(201,171,119,.4);border-radius:4px}

/* Header */
.cv-header{position:fixed;top:0;z-index:100;width:100%;height:var(--header-height);background:var(--cv-charcoal);border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center}
.cv-header-inner{width:100%;max-width:1280px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;color:var(--cv-beige)}
.cv-brand-area{display:flex;align-items:center;gap:12px;color:var(--cv-beige)}.cv-logo-img{height:32px;width:auto;transition:transform .5s}.cv-brand-area:hover .cv-logo-img{transform:scale(1.05)}
.cv-site-title{font-family:var(--cv-font-serif);font-size:1.1rem;letter-spacing:.15em;text-transform:uppercase}
.cv-nav-links{display:flex;align-items:center;gap:28px}.cv-nav-item{font-family:var(--cv-font-serif);font-size:1rem;letter-spacing:.05em;opacity:.9;transition:all .3s}.cv-nav-item:hover{opacity:1;color:var(--cv-brass)}
.cv-btn-join{border:1px solid var(--cv-beige);padding:6px 20px;border-radius:50px;font-family:var(--cv-font-serif);font-size:1rem;transition:all .3s}.cv-btn-join:hover{background:var(--cv-beige);color:var(--cv-green)}
.cv-mobile-toggle{display:none;padding:4px}
@media(max-width:1024px){.cv-nav-links{display:none}.cv-mobile-toggle{display:block}}
@media(max-width:768px){.cv-site-title{display:none}}
.cv-mobile-nav{position:fixed;inset:0;background:rgba(24,41,31,.96);backdrop-filter:blur(12px);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;display:flex;align-items:center;justify-content:center}
.cv-mobile-nav.is-open{opacity:1;pointer-events:auto}
.cv-mobile-nav-content{text-align:center;display:flex;flex-direction:column;gap:24px}.cv-mobile-close{position:absolute;top:20px;right:20px}
.cv-mobile-link{font-family:var(--cv-font-serif);font-size:1.5rem;letter-spacing:.08em;transition:color .3s}.cv-mobile-link:hover{color:var(--cv-brass)}
.cv-mobile-cta{border:1px solid var(--cv-brass);padding:8px 32px;border-radius:50px;display:inline-block;margin-top:12px}
.cv-app{position:relative;min-height:100vh;padding-top:var(--header-height)}
.cv-app::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 0%,rgba(201,171,119,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(201,171,119,.03) 0%,transparent 50%);pointer-events:none;z-index:0}
.cv-watermark{position:fixed;bottom:-5%;right:-5%;width:35vw;max-width:400px;opacity:.02;pointer-events:none;z-index:0}
.cv-footer{background:var(--cv-charcoal);padding:60px 24px;border-top:1px solid rgba(255,255,255,.05)}
.cv-footer-cols{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px}
.cv-foot-col{display:flex;flex-direction:column;gap:8px}.cv-foot-col h3{font-family:var(--cv-font-serif);font-size:1.2rem;font-weight:300;margin-bottom:16px}
.cv-foot-link,.cv-foot-text{font-family:var(--cv-font-sans);font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:rgba(229,222,208,.6);transition:color .3s}.cv-foot-link a{color:inherit}.cv-foot-link:hover,.cv-foot-link a:hover{color:var(--cv-brass)}
.cv-foot-right{text-align:right}.cv-copyright{margin-top:20px;font-size:.6rem;text-transform:none;opacity:.4}
@media(max-width:768px){.cv-footer-cols{grid-template-columns:1fr}.cv-foot-right{text-align:left}}

/* ═══ HERO ═══ */
.enc-wrapper{position:relative;z-index:1}
.enc-hero{text-align:center;padding:36px 24px 20px;max-width:900px;margin:0 auto}
.enc-title{font-family:var(--cv-font-serif);font-weight:300;font-size:clamp(2rem,5vw,3.5rem);color:var(--cv-beige);line-height:1.1;margin-bottom:4px;opacity:0;animation:encUp .7s .05s forwards}
.enc-title em{font-style:italic;color:var(--cv-brass-warm)}
.enc-divider{width:60px;height:1px;background:var(--cv-brass);opacity:.5;margin:10px auto;animation:encBreathe 6s ease-in-out infinite}
.enc-subtitle{font-family:var(--cv-font-sans);font-weight:300;font-size:clamp(.76rem,1.2vw,.85rem);color:var(--cv-beige);opacity:0;line-height:1.65;max-width:480px;margin:0 auto 14px;animation:encFade .7s .25s forwards}
.enc-subtitle .wb{font-weight:500;color:var(--cv-brass-warm)}.enc-subtitle .si{font-style:italic;opacity:.9}
.enc-stats{display:flex;justify-content:center;gap:32px;margin-bottom:14px;opacity:0;animation:encFade .7s .35s forwards}
.enc-stat{text-align:center}.enc-stat-num{font-family:var(--cv-font-serif);font-weight:300;font-size:1.6rem;color:var(--cv-brass);line-height:1}
.enc-stat-label{font-family:var(--cv-font-sans);font-weight:600;font-size:.48rem;text-transform:uppercase;letter-spacing:.18em;color:var(--cv-beige);opacity:.4;margin-top:2px}
.enc-stat.hero-stat .enc-stat-num{font-size:2.2rem;color:var(--cv-beige);opacity:.9}
.enc-stat.hero-stat .enc-stat-label{font-size:.55rem;color:var(--cv-brass);opacity:.7;letter-spacing:.25em}
.enc-search-wrap{max-width:440px;margin:0 auto 6px;position:relative;opacity:0;animation:encUp .7s .45s forwards}
.enc-search{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(229,222,208,.12);border-radius:50px;padding:10px 44px 10px 18px;font-size:.82rem;font-weight:300;color:var(--cv-beige);outline:none;transition:all .3s}
.enc-search::placeholder{color:rgba(229,222,208,.3)}
.enc-search:focus{border-color:rgba(201,171,119,.45);background:rgba(255,255,255,.08)}
.enc-search-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--cv-brass);opacity:.5;pointer-events:none}
.enc-search-clear{position:absolute;right:38px;top:50%;transform:translateY(-50%);color:var(--cv-beige);opacity:0;cursor:pointer;transition:opacity .2s;font-size:1rem}.enc-search-clear.vis{opacity:.5}.enc-search-clear:hover{opacity:1}

/* Tabs + shuffle */
.enc-tab-row{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:16px;opacity:0;animation:encFade .7s .55s forwards}
.enc-tabs{display:flex;gap:3px;background:rgba(255,255,255,.04);border-radius:50px;padding:3px}
.enc-tab{font-family:var(--cv-font-sans);font-weight:500;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;padding:6px 16px;border-radius:50px;color:var(--cv-beige);opacity:.4;transition:all .3s;cursor:pointer}
.enc-tab:hover{opacity:.7}.enc-tab.active{background:var(--cv-brass);color:var(--cv-green);opacity:1}
.enc-shuffle{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:var(--cv-brass);opacity:.5;transition:all .3s;cursor:pointer}
.enc-shuffle:hover{opacity:1;background:rgba(255,255,255,.1);transform:rotate(180deg)}

/* ═══ TAG SCROLLER ═══ */
.enc-tagbar{max-width:1100px;margin:0 auto 20px;padding:0 24px;overflow:hidden;position:relative}
.enc-tagbar::after{content:'';position:absolute;right:0;top:0;bottom:0;width:60px;background:linear-gradient(to right,transparent,var(--cv-green));pointer-events:none;z-index:1}
.enc-tagbar::before{content:'';position:absolute;left:0;top:0;bottom:0;width:30px;background:linear-gradient(to left,transparent,var(--cv-green));pointer-events:none;z-index:1}
.enc-tagbar-inner{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:4px 0;-webkit-overflow-scrolling:touch}
.enc-tagbar-inner::-webkit-scrollbar{display:none}
.enc-tagpill{flex-shrink:0;font-family:var(--cv-font-sans);font-size:.6rem;font-weight:400;padding:5px 14px;border-radius:50px;border:1px solid rgba(201,171,119,.2);color:var(--cv-beige);opacity:.55;cursor:pointer;transition:all .25s;white-space:nowrap}
.enc-tagpill:hover{opacity:.85;border-color:rgba(201,171,119,.45)}

/* ═══ CHAPTERS ═══ */
.enc-chapters{max-width:1100px;margin:0 auto;padding:0 0 40px}
.enc-chapter{margin-bottom:24px;opacity:0;animation:encUp .5s forwards}
.enc-chapter:nth-child(1){animation-delay:.05s}.enc-chapter:nth-child(2){animation-delay:.1s}.enc-chapter:nth-child(3){animation-delay:.15s}
.enc-chapter-header{display:flex;align-items:baseline;gap:10px;padding:0 24px;margin-bottom:8px}
.enc-chapter-name{font-family:var(--cv-font-serif);font-weight:300;font-size:1.15rem;color:var(--cv-beige)}
.enc-chapter-count{font-family:var(--cv-font-sans);font-size:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--cv-brass);opacity:.4}
.enc-chapter-more{margin-left:auto;font-family:var(--cv-font-sans);font-size:.52rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--cv-brass);opacity:.4;cursor:pointer;transition:opacity .3s;display:flex;align-items:center;gap:4px}.enc-chapter-more:hover{opacity:1}

/* Pattern: horizontal scroll */
.enc-hscroll{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;padding:0 24px 6px;-webkit-overflow-scrolling:touch}
.enc-hscroll::-webkit-scrollbar{display:none}
.enc-hcard{flex-shrink:0;width:260px;background:rgba(255,255,255,.035);border:1px solid rgba(229,222,208,.07);border-radius:12px;padding:16px 18px;cursor:pointer;transition:all .3s;position:relative}
.enc-hcard:hover{background:rgba(255,255,255,.07);border-color:rgba(201,171,119,.2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.enc-hcard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cv-brass);opacity:0;transition:opacity .3s;border-radius:3px 0 0 3px}.enc-hcard:hover::before{opacity:.6}
.enc-hcard-title{font-family:var(--cv-font-serif);font-weight:300;font-size:.88rem;color:var(--cv-beige);line-height:1.35;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.enc-hcard-source{font-family:var(--cv-font-sans);font-weight:500;font-size:.55rem;color:var(--cv-brass-warm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Pattern: 3-col grid */
.enc-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding:0 24px}

/* Pattern: spotlight (large featured) */
.enc-spotlight{background:rgba(255,255,255,.045);border:1px solid rgba(201,171,119,.12);border-radius:16px;padding:28px 32px;cursor:pointer;transition:all .35s;position:relative;margin:0 24px;overflow:hidden}
.enc-spotlight:hover{background:rgba(255,255,255,.08);border-color:rgba(201,171,119,.25);transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,0,0,.2)}
.enc-spotlight::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--cv-brass);opacity:0;transition:opacity .3s;border-radius:4px 0 0 4px}.enc-spotlight:hover::before{opacity:.7}
.enc-spotlight-title{font-family:var(--cv-font-serif);font-weight:300;font-size:clamp(1.1rem,2vw,1.4rem);color:var(--cv-beige);line-height:1.4;margin-bottom:10px}
.enc-spotlight-source{font-family:var(--cv-font-sans);font-weight:500;font-size:.68rem;color:var(--cv-brass-warm)}
.enc-spotlight-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}

.enc-more-wrap{display:flex;justify-content:center;margin-top:8px;padding:0 24px}
.enc-more-btn{font-family:var(--cv-font-sans);font-size:.68rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--cv-brass);border:1px solid rgba(201,171,119,.3);padding:9px 28px;border-radius:50px;cursor:pointer;transition:all .3s}
.enc-more-btn:hover{background:var(--cv-brass);color:var(--cv-green)}

/* ═══ BROWSE (Activity/Impact) — alpha groups, compact pills ═══ */
.enc-browse{max-width:1100px;margin:0 auto;padding:0 24px 50px}
.enc-browse-count{text-align:center;font-family:var(--cv-font-sans);font-size:.65rem;color:var(--cv-beige);opacity:.3;margin-bottom:16px}
.enc-alpha-group{margin-bottom:18px}
.enc-alpha-letter{font-family:var(--cv-font-serif);font-weight:300;font-size:1.3rem;color:var(--cv-brass);opacity:.35;margin-bottom:6px;padding-left:2px}
.enc-alpha-grid{display:flex;flex-wrap:wrap;gap:6px}
.enc-alpha-card{background:rgba(255,255,255,.04);border:1px solid rgba(229,222,208,.07);border-radius:10px;padding:10px 16px;cursor:pointer;transition:all .3s;display:flex;align-items:baseline;gap:8px}
.enc-alpha-card:hover{background:rgba(255,255,255,.08);border-color:rgba(201,171,119,.25);transform:translateY(-1px)}
.enc-alpha-card-name{font-family:var(--cv-font-serif);font-weight:300;font-size:.88rem;color:var(--cv-beige);line-height:1.2}
.enc-alpha-card-num{font-family:var(--cv-font-sans);font-size:.5rem;font-weight:600;color:var(--cv-brass);opacity:.55}

/* Drill header */
.enc-drill-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid rgba(229,222,208,.06)}
.enc-drill-back{display:flex;align-items:center;gap:5px;font-family:var(--cv-font-sans);font-size:.68rem;font-weight:500;color:var(--cv-brass);opacity:.7;cursor:pointer;transition:opacity .3s;text-transform:uppercase;letter-spacing:.08em}.enc-drill-back:hover{opacity:1}
.enc-drill-name{font-family:var(--cv-font-serif);font-weight:300;font-size:1.4rem;color:var(--cv-beige)}
.enc-drill-count{font-family:var(--cv-font-sans);font-size:.6rem;color:var(--cv-brass);opacity:.45}

/* Search/drill results list */
.enc-results{max-width:1100px;margin:0 auto;padding:0 24px 50px}
.enc-results-count{font-family:var(--cv-font-sans);font-size:.65rem;color:var(--cv-beige);opacity:.3;margin-bottom:14px;text-align:center}
.enc-results-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.enc-fact{background:rgba(255,255,255,.03);border:1px solid rgba(229,222,208,.07);border-radius:12px;padding:16px 18px;cursor:pointer;transition:all .3s;position:relative}
.enc-fact:hover{background:rgba(255,255,255,.06);border-color:rgba(201,171,119,.2);transform:translateY(-1px)}
.enc-fact::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cv-brass);opacity:0;transition:opacity .3s;border-radius:3px 0 0 3px}.enc-fact:hover::before{opacity:.5}
.enc-fact-title{font-family:var(--cv-font-serif);font-weight:300;font-size:.88rem;color:var(--cv-beige);line-height:1.4;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.enc-fact-source{font-family:var(--cv-font-sans);font-weight:500;font-size:.58rem;color:var(--cv-brass-warm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.enc-tag{font-family:var(--cv-font-sans);font-size:.48rem;font-weight:500;padding:2px 7px;border-radius:50px;text-transform:uppercase;letter-spacing:.06em}
.enc-tag-a{border:1px solid rgba(201,171,119,.25);color:var(--cv-brass)}.enc-tag-i{border:1px solid rgba(229,222,208,.1);color:var(--cv-beige);opacity:.5}

/* Empty */
.enc-empty{text-align:center;padding:50px 24px}
.enc-empty-title{font-family:var(--cv-font-serif);font-weight:300;font-size:1.3rem;margin-bottom:4px}
.enc-empty-text{font-family:var(--cv-font-sans);font-size:.8rem;opacity:.4}

/* ═══ MODAL ═══ */
.enc-modal-backdrop{position:fixed;inset:0;background:rgba(24,41,31,.88);backdrop-filter:blur(10px);z-index:300;opacity:0;pointer-events:none;transition:opacity .3s}
.enc-modal-backdrop.open{opacity:1;pointer-events:auto}
.enc-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);z-index:301;width:90%;max-width:660px;max-height:85vh;overflow-y:auto;background:var(--cv-green-light);border:1px solid rgba(255,255,255,.1);border-radius:20px;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);scrollbar-width:thin;scrollbar-color:rgba(201,171,119,.3) transparent}
.enc-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.enc-modal::-webkit-scrollbar{width:4px}.enc-modal::-webkit-scrollbar-track{background:transparent}.enc-modal::-webkit-scrollbar-thumb{background:rgba(201,171,119,.3);border-radius:2px}
.enc-modal-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:var(--cv-beige);opacity:.6;transition:all .3s;z-index:2}.enc-modal-close:hover{opacity:1;background:rgba(255,255,255,.12)}
.enc-modal-body{padding:36px 32px 32px;position:relative}
.enc-modal-label{font-family:var(--cv-font-sans);font-weight:700;font-size:.5rem;text-transform:uppercase;letter-spacing:.35em;color:var(--cv-brass);margin-bottom:12px}
.enc-modal-title{font-family:var(--cv-font-serif);font-weight:300;font-size:clamp(1.2rem,2.3vw,1.55rem);color:var(--cv-beige);line-height:1.4;margin-bottom:14px}
.enc-modal-source{font-family:var(--cv-font-sans);font-weight:500;font-size:.75rem;color:var(--cv-brass-warm);margin-bottom:16px}
.enc-modal-source .lt{font-weight:400;font-size:.6rem;color:var(--cv-beige);opacity:.35;text-transform:uppercase;letter-spacing:.05em}
.enc-modal-hr{width:100%;height:1px;background:rgba(229,222,208,.08);margin:0 0 18px}
.enc-modal-section{margin-bottom:18px}
.enc-modal-section-label{font-family:var(--cv-font-sans);font-weight:600;font-size:.5rem;text-transform:uppercase;letter-spacing:.25em;color:var(--cv-brass);margin-bottom:6px}
.enc-modal-text{font-family:var(--cv-font-sans);font-weight:300;font-size:.8rem;color:var(--cv-beige);opacity:.7;line-height:1.8}
.enc-modal-citation{font-family:var(--cv-font-sans);font-weight:300;font-size:.72rem;color:var(--cv-beige);opacity:.4;line-height:1.7;font-style:italic}
.enc-modal-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px}
.enc-modal-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.enc-source-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--cv-font-sans);font-size:.65rem;font-weight:500;color:var(--cv-brass);border:1px solid rgba(201,171,119,.3);padding:7px 16px;border-radius:50px;transition:all .3s}
.enc-source-btn:hover{background:var(--cv-brass);color:var(--cv-green)}.enc-source-btn svg{width:12px;height:12px}

@keyframes encFade{from{opacity:0}to{opacity:1}}
@keyframes encUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes encBreathe{0%,100%{opacity:.3;width:50px}50%{opacity:.6;width:70px}}

.enc-btt{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--cv-brass);color:var(--cv-green);display:flex;align-items:center;justify-content:center;z-index:90;opacity:0;pointer-events:none;transition:all .3s;box-shadow:0 4px 16px rgba(0,0,0,.3)}
/* ═══ VISUALISE TAB ═══ */
.enc-tab-vis{border:1px solid rgba(201,171,119,.5);display:inline-flex;align-items:center;gap:5px}
.enc-tab-vis.active{border-color:var(--cv-brass);background:var(--cv-brass);color:var(--cv-green)}
.enc-tab-vis svg{width:11px;height:11px}

.enc-vis-callout{text-align:center;font-family:var(--cv-font-sans);font-size:.72rem;color:var(--cv-beige);opacity:.35;margin-bottom:16px;font-style:italic}

.enc-vis-wrap{max-width:1100px;margin:0 auto;padding:0 24px 50px}
.enc-vis-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;overflow:hidden}
.enc-vis-tile{background:rgba(255,255,255,.035);border:1px solid rgba(229,222,208,.07);border-radius:16px;padding:28px 22px 22px;cursor:pointer;transition:all .35s;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:260px;min-width:0;overflow:hidden}
.enc-vis-tile:hover{background:rgba(255,255,255,.07);border-color:rgba(201,171,119,.2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.18)}

.enc-vis-chart{display:flex;justify-content:center;align-items:center;margin-bottom:14px}
.enc-vis-chart svg{display:block;overflow:visible}
.enc-vis-chart .enc-pie-wrap{width:100px;height:100px;border-radius:50%;overflow:hidden}

.enc-vis-val{font-family:var(--cv-font-serif);font-weight:300;font-size:1.8rem;color:var(--cv-brass);line-height:1;margin-bottom:10px}
.enc-vis-val.big{font-size:3.6rem;color:var(--cv-beige);opacity:.9;margin-bottom:14px}
.enc-vis-val .unit{font-size:.55em;opacity:.55;margin-left:2px}

.enc-vis-title{font-family:var(--cv-font-serif);font-weight:300;font-size:1rem;color:var(--cv-beige);line-height:1.45;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;opacity:.8}
.enc-vis-source{font-family:var(--cv-font-sans);font-weight:500;font-size:.68rem;color:var(--cv-brass-warm);opacity:.55;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

.enc-vis-refresh{display:flex;justify-content:center;margin-bottom:20px}
.enc-vis-refresh-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--cv-font-sans);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--cv-brass);border:1px solid rgba(201,171,119,.35);padding:11px 32px;border-radius:50px;cursor:pointer;transition:all .3s}
.enc-vis-refresh-btn:hover{background:var(--cv-brass);color:var(--cv-green)}
.enc-vis-refresh-btn svg{width:14px;height:14px;transition:transform .4s}
.enc-vis-refresh-btn:hover svg{transform:rotate(180deg)}
.enc-vis-refresh-sub{display:flex;justify-content:center;margin-top:20px}
.enc-vis-refresh-sub .enc-vis-refresh-btn{font-size:.6rem;padding:8px 22px;opacity:.5;border-color:rgba(201,171,119,.2)}
.enc-vis-refresh-sub .enc-vis-refresh-btn:hover{opacity:1}

/* People icons */
.enc-people-row{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.enc-person{opacity:.12}.enc-person.filled{opacity:1;color:var(--cv-brass)}
.enc-person svg{width:22px;height:24px}

/* Gauge label */
.enc-gauge-label{font-family:var(--cv-font-sans);font-size:.55rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cv-beige);opacity:.3;margin-top:4px}

.enc-btt.vis{opacity:1;pointer-events:auto}.enc-btt:hover{transform:scale(1.1)}

@media(max-width:768px){
    .enc-hero{padding:24px 16px 14px}.enc-stats{gap:14px;flex-wrap:wrap}.enc-stat-num{font-size:1.3rem}.enc-stat.hero-stat .enc-stat-num{font-size:1.8rem}
    .enc-tabs{flex-wrap:nowrap}.enc-tab{padding:5px 12px;font-size:.58rem}
    .enc-tagbar{padding:0 16px}.enc-chapters{padding:0 0 30px}
    .enc-chapter-header{padding:0 16px}.enc-hscroll{padding:0 16px 6px}.enc-hcard{width:220px}
    .enc-grid3{grid-template-columns:1fr;padding:0 16px}.enc-spotlight{margin:0 16px}
    .enc-browse{padding:0 16px 40px}
    .enc-results{padding:0 16px 40px}.enc-results-grid{grid-template-columns:1fr}
    .enc-modal{width:95%;max-height:90vh;border-radius:16px}.enc-modal-body{padding:24px 18px 20px}
    .enc-chapter-name{font-size:1.05rem}.enc-drill-name{font-size:1.1rem}
    .enc-vis-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .enc-vis-tile{min-height:180px;padding:14px 12px 12px}
    .enc-vis-wrap{padding:0 16px 40px}
}
@media(max-width:480px){.enc-results-grid{grid-template-columns:1fr}.enc-alpha-card{padding:8px 12px}.enc-alpha-card-name{font-size:.8rem}.enc-vis-grid{grid-template-columns:1fr 1fr}}

/* ═══ LOADING OVERLAY ═══ */
.enc-loading{position:fixed;inset:0;z-index:250;display:flex;align-items:center;justify-content:center;background:rgba(24,41,31,.55);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s ease}
.enc-loading.active{opacity:1;pointer-events:auto}
.enc-loading-spinner{width:40px;height:40px;border:2px solid rgba(201,171,119,.15);border-top-color:var(--cv-brass);border-radius:50%;animation:encSpin .7s linear infinite}
@keyframes encSpin{to{transform:rotate(360deg)}}
