.project-detail-page{width:100%;@media(max-width:1023px){padding-bottom: clamp(6rem,15vh,10rem);}}.project-showcase{display:flex;flex-direction:column;justify-content:center;padding:2rem 0 1rem;border-bottom:1px solid var(--color-border);background:radial-gradient(circle at top right,var(--color-glow),transparent 60%);@media(min-width:1024px){min-height: 90vh;}}.project-hero{position:relative;width:100%;max-width:1200px;margin:0 auto;display:flex;justify-content:center;padding:1rem clamp(1rem,5vw,2rem);@media(min-width:1024px){padding: 1rem 2rem;}& .project-hero__content { width: 100%; }}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-accent);text-decoration:none;font-family:var(--font-mono);font-size:.85rem;font-weight:600;margin-bottom:1.5rem;transition:transform .3s ease;&:hover { transform:translateX(-5px); }}.project-category{display:block;font-family:var(--font-mono);font-size:.8rem;color:var(--color-text);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.5rem}.project-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--color-text-heading);line-height:1.1;margin-bottom:1.5rem}.project-meta{display:flex;flex-direction:column;gap:1.25rem;@media(min-width:768px){flex-direction: row; align-items: center; justify-content: space-between;}& .project-meta-details { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; } & .project-date { display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.9rem; color: var(--color-text); } & .status-badge { padding: 0.4rem 1rem; background: var(--color-accent-dim); color: var(--color-accent); border: 1px solid var(--color-accent); font-family: var(--font-mono); font-size: 0.7rem; font-weight: 800; border-radius: 4px; }}.project-carousel-wrapper{position:relative;width:100%;@media(min-width:1024px){padding: 0.5rem 0 3rem;}}.project-carousel{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding:0 5%;padding:1rem 5%;scrollbar-width:none;-ms-overflow-style:none;&::-webkit-scrollbar { display:none; }}.carousel-item{flex:0 0 85%;scroll-snap-align:center;border-radius:12px;overflow:hidden;border:1px solid var(--color-border);transition:transform .4s ease,opacity .4s ease,border-color .4s ease,box-shadow .4s ease;opacity:.5;transform:scale(.95);cursor:pointer;@media(min-width:1024px){flex: 0 0 70%;}&.active, &:hover, &:focus-within { opacity: 1; transform: scale(1); z-index: 10; border-color: var(--color-accent); box-shadow: 0 8px 40px rgba(16, 185, 129, 0.15); } & img { width: 100%; height: auto; display: block; object-fit: cover; aspect-ratio: 16/9; }}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20;color:var(--color-text);transition:all .3s ease;&:hover { background:var(--color-accent); color:var(--color-bg-base); border-color:var(--color-accent); } &.prev-arrow { left:0.5rem; @media (min-width:768px) { left:1rem; } } &.next-arrow { right:0.5rem; @media (min-width:768px) { right:1rem; } }}.project-layout-grid{display:grid;grid-template-columns:minmax(0,1fr);column-gap:4rem;max-width:1200px;margin:0 auto;padding:clamp(1.5rem,5vw,2.5rem)clamp(1rem,5vw,2rem);@media(min-width:1024px){grid-template-columns: minmax(0,1fr) 320px; align-items: start; padding: 2rem 2rem 0;}}.project-main-content{min-width:0;overflow:hidden}.custom-article{font-size:1.1rem;line-height:1.8;color:var(--color-text);overflow-wrap:break-word;word-break:break-word;min-width:0;max-width:100%;margin-bottom:2rem;& h2 { font-size: 1.8rem; color: var(--color-text-heading); font-weight: 700; background: none; -webkit-text-fill-color: unset; margin-top: 0 !important; margin-bottom: 1rem !important; } & h3 { font-size: 1.4rem; color: var(--color-text-heading); margin-top: 0 !important; margin-bottom: 1rem !important; } & p { margin-top: 0 !important; margin-bottom: 1.5rem !important; } & table { display: block !important; width: fit-content !important; min-width: 0 !important; max-width: 100% !important; overflow-x: auto !important; overflow-y: hidden !important; -webkit-overflow-scrolling: touch; border-collapse: collapse; margin-top: 0 !important; margin-bottom: 1.5rem !important; } & th, & td { padding: 0.6rem 0.75rem; border: 1px solid var(--color-border); font-size: 0.9rem; vertical-align: middle; white-space: nowrap; } & thead th { color: var(--color-accent); font-weight: 700; text-align: left; } & details { margin-top: 0 !important; margin-bottom: 1.5rem !important; padding: 0 !important; border: 1px solid var(--color-border) !important; border-radius: 12px !important; background: var(--color-surface) !important; overflow: hidden; } & summary { color: var(--color-text-heading) !important; opacity: 1; display: flex !important; align-items: center !important; flex-direction: row !important; } & details>summary { padding: 0.75rem 0.9rem !important; background: transparent !important; } & details>summary:hover { background: transparent !important; } & details>div { padding: 0 1rem 1rem !important; } & details>summary strong { font-size: 1rem !important; } & .hx\:overflow-x-auto.hx\:flex { margin-top: 0 !important; margin-bottom: 1.5rem !important; } & .hextra-cards { margin-top: 0 !important; margin-bottom: 1.5rem !important; & .hextra-card { background: var(--color-surface) !important; border: 1px solid var(--color-border) !important; border-radius: 12px !important; text-decoration: none !important; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important; cursor: pointer !important; & .hextra-card-icon { font-family: var(--font-sans) !important; font-size: 1.05rem !important; font-weight: 600 !important; color: var(--color-text-heading) !important; display: flex !important; align-items: center !important; gap: 0.75rem !important; padding-top: 1.25rem !important; padding-left: 1.25rem !important; padding-right: 1.25rem !important; & svg { color: var(--color-accent) !important; stroke: var(--color-accent) !important; width: 1.35rem !important; height: 1.35rem !important; flex-shrink: 0 !important; transition: transform 0.3s ease !important; } } & .hextra-card-subtitle { font-family: var(--font-sans) !important; font-size: 0.88rem !important; line-height: 1.6 !important; color: var(--color-text) !important; padding-left: 1.25rem !important; padding-right: 1.25rem !important; margin-bottom: 1.25rem !important; margin-top: 0.5rem !important; } &:hover { background: color-mix(in srgb, var(--color-accent) 4%, var(--color-surface)) !important; border-color: var(--color-accent) !important; transform: translateY(-4px) !important; & .hextra-card-icon svg { transform: scale(1.15) !important; } } } } & ul { list-style-type: disc; padding-left: 1.5rem; margin-top: 0 !important; margin-bottom: 1.5rem !important; } & ol { padding-left: 1.5rem; margin-top: 0 !important; margin-bottom: 1.5rem !important; } & li { margin-bottom: 0.5rem; } & strong { color: var(--color-text-heading); font-weight: 600; } & :not(pre)>code { font-family: var(--font-mono); background: rgba(16, 185, 129, 0.08); padding: 0.15em 0.4em; border-radius: 4px; font-size: 0.875em; color: var(--color-accent); border: 1px solid rgba(16, 185, 129, 0.2); box-shadow: none; }}html.light .custom-article th,html.light .custom-article td{background:#fff;color:#1e293b;border-color:#e2e8f0}html.light .custom-article thead th{background:#f0fdf4;color:#059669;border-color:#d1fae5}html.dark .custom-article thead th{background:color-mix(in srgb,var(--color-accent) 14%,#0f172a 86%);color:#34d399;border-color:color-mix(in srgb,var(--color-accent) 18%,#1e293b 82%)}html.dark .custom-article details{background:rgba(15,23,42,.72);border-color:color-mix(in srgb,var(--color-accent) 16%,#1e293b 84%)}html.dark .custom-article details>summary{background:0 0}html.dark .custom-article details>summary:hover{background:0 0}html.light .custom-article details{background:#fff;border-color:#e2e8f0}.custom-article .hextra-steps{border-color:var(--color-border) !important;& h3:not(.no-step-marker), & h2:not(.no-step-marker) { position: relative !important; &::before { top: 50% !important; transform: translateY(-50%) !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; line-height: 1 !important; } }}.custom-article .hextra-steps h3:not(.no-step-marker)::before,.custom-article .hextra-steps h2:not(.no-step-marker)::before{background:color-mix(in srgb,var(--color-accent) 12%,var(--color-surface)) !important;border-color:var(--color-surface) !important;color:var(--color-accent) !important;box-shadow:0 0 0 1px var(--color-border)}html.light .custom-article .hextra-steps h3:not(.no-step-marker)::before,html.light .custom-article .hextra-steps h2:not(.no-step-marker)::before{background:#f0fdf4 !important;border-color:#fff !important;color:#059669 !important;box-shadow:0 0 0 1px #d1fae5}html.dark .custom-article .hextra-steps h3:not(.no-step-marker)::before,html.dark .custom-article .hextra-steps h2:not(.no-step-marker)::before{background:color-mix(in srgb,var(--color-accent) 18%,#0f172a 82%) !important;border-color:#0f172a !important;color:#34d399 !important;box-shadow:0 0 0 1px color-mix(in srgb,var(--color-accent) 18%,#1e293b 82%)}.hextra-code-block{border-radius:12px;border:1px solid rgba(255,255,255,7%);background:#0d1117;box-shadow:0 8px 24px rgba(0,0,0,.4);margin-top:0 !important;margin-bottom:1.5rem !important;overflow:hidden;& pre { background: #0d1117 !important; color: #c9d1d9 !important; border: none; border-radius: 0; box-shadow: none; margin: 0; padding: 1.1rem 1.4rem; overflow-x: auto; } & code { background: transparent !important; border: none; padding: 0; font-family: var(--font-mono); font-size: 0.875rem; line-height: 1.75; } & .chroma { background: #0d1117 !important; color: #c9d1d9 !important; } & .hextra-code-filename { background: #161b22; border-bottom: 1px solid rgba(255, 255, 255, 0.07); color: #8b949e; font-family: var(--font-mono); font-size: 0.8rem; border-radius: 0; }}.hextra-code-copy-btn-container{background:0 0}.hextra-code-copy-btn{background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.35);border-radius:6px;color:var(--color-accent);padding:.35rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;backdrop-filter:none;opacity:1;&:hover { background:rgba(16,185,129,0.28); border-color:var(--color-accent); }}.hextra-copy-icon,.hextra-success-icon{color:var(--color-accent);fill:none;stroke:var(--color-accent)}.sticky-sidebar{position:sticky;top:2rem;display:flex;flex-direction:column;gap:1.25rem;align-self:start;max-height:calc(100vh - 5rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border)transparent;&::-webkit-scrollbar { width:6px; } &::-webkit-scrollbar-track { background:transparent; } &::-webkit-scrollbar-thumb { background-color:var(--color-border); border-radius:10px; } @media (max-width:1023px) { position:static; max-height:none; overflow:visible; margin-top:2rem; }}.sidebar-block{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;& h3 { font-family: var(--font-mono); font-size: 0.9rem; color: var(--color-text-heading); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 0; margin-bottom: 1.25rem; border-bottom: 1px solid var(--color-border); padding-bottom: 0.75rem; } &.project-links-block { @media (max-width: 1023px) { position: fixed; bottom: 0; left: 0; right: 0; z-index: 1000; background: rgba(3, 7, 18, 0.8); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-top: 1px solid var(--color-border); border-radius: 0; box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.5); display: flex; flex-direction: row; align-items: center; justify-content: center; gap: 0.75rem; padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom)); overflow-x: auto; scrollbar-width: none; @supports (justify-content: safe center) { justify-content: safe center; } &::-webkit-scrollbar { display: none; } & h3, & .sidebar-hint, & .sidebar-separator, & .sidebar-note { display: none; } & .sidebar-sub-section, & .project-links, & .code-buttons-grid, & .vertical-links { display: contents; } & .btn-primary, & .btn-secondary { flex: 0 0 auto; width: auto; min-width: 120px; max-width: 180px; font-size: 0.8rem; padding: 0.6rem 1.25rem; white-space: nowrap; } } } & .sidebar-note { @media (max-width: 1023px) { display: block; text-align: center; margin: 1.5rem 0 0.5rem; font-size: 0.85rem; opacity: 0.7; padding: 0 1.5rem; line-height: 1.5; } }}html.light .sidebar-block.project-links-block{@media(max-width:1023px){background: rgba(241,245,249,0.9); border-top-color: rgba(0,0,0,0.1);}}.info-list{list-style:none;padding:0;margin:0;& li { display: grid; grid-template-columns: minmax(5.75rem, 0.42fr) 1fr; gap: 0.75rem; align-items: baseline; margin-bottom: 0.75rem; font-size: 0.9rem; line-height: 1.45; & strong { color: var(--color-text-heading); font-size: 0.78rem; } }}.project-links{display:flex;flex-direction:column;gap:.85rem}.code-buttons-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;@media(min-width:380px){grid-template-columns: repeat(auto-fit,minmax(120px,1fr));}}.btn-primary,.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.85rem 1rem;border-radius:8px;font-weight:600;font-size:.95rem;text-decoration:none;transition:all .3s ease;cursor:pointer}.btn-small{padding:.6rem .5rem;font-size:.85rem}.btn-primary{background:var(--color-accent);color:var(--color-bg-base);border:none;&:hover { background:#0ea171; transform:translateY(-2px); box-shadow:0 10px 20px var(--color-accent-dim); }}.btn-secondary{border:1px solid var(--color-border);color:var(--color-text-heading);background:0 0;&:hover { background:var(--color-surface); border-color:var(--color-accent); color:var(--color-accent); transform:translateY(-2px); }}.btn-lang-html{border-color:color-mix(in srgb,var(--tech-html) 40%,transparent);color:var(--tech-html)}.btn-lang-html:hover{background:color-mix(in srgb,var(--tech-html) 12%,transparent);border-color:var(--tech-html);color:var(--tech-html)}.btn-lang-css{border-color:color-mix(in srgb,var(--tech-css) 40%,transparent);color:var(--tech-css)}.btn-lang-css:hover{background:color-mix(in srgb,var(--tech-css) 12%,transparent);border-color:var(--tech-css);color:var(--tech-css)}.btn-lang-js{border-color:color-mix(in srgb,var(--tech-js) 40%,transparent);color:var(--tech-js)}.btn-lang-js:hover{background:color-mix(in srgb,var(--tech-js) 12%,transparent);border-color:var(--tech-js);color:var(--tech-js)}.btn-lang-schema,.btn-lang-json{border-color:color-mix(in srgb,var(--tech-json) 40%,transparent);color:var(--tech-json)}.btn-lang-schema:hover,.btn-lang-json:hover{background:color-mix(in srgb,var(--tech-json) 12%,transparent);border-color:var(--tech-json);color:var(--tech-json)}.btn-lang-xml{border-color:color-mix(in srgb,var(--tech-xml) 40%,transparent);color:var(--tech-xml)}.btn-lang-xml:hover{background:color-mix(in srgb,var(--tech-xml) 12%,transparent);border-color:var(--tech-xml);color:var(--tech-xml)}.btn-lang-xsl{border-color:color-mix(in srgb,var(--tech-xslt) 40%,transparent);color:var(--tech-xslt)}.btn-lang-xsl:hover{background:color-mix(in srgb,var(--tech-xslt) 12%,transparent);border-color:var(--tech-xslt);color:var(--tech-xslt)}.btn-lang-sh{border-color:color-mix(in srgb,var(--tech-sh) 40%,transparent);color:var(--tech-sh)}.btn-lang-sh:hover{background:color-mix(in srgb,var(--tech-sh) 12%,transparent);border-color:var(--tech-sh);color:var(--tech-sh)}.btn-lang-xsd{border-color:color-mix(in srgb,var(--tech-xsd) 40%,transparent);color:var(--tech-xsd)}.btn-lang-xsd:hover{background:color-mix(in srgb,var(--tech-xsd) 12%,transparent);border-color:var(--tech-xsd);color:var(--tech-xsd)}.btn-lang-dtd{border-color:color-mix(in srgb,var(--tech-dtd) 40%,transparent);color:var(--tech-dtd)}.btn-lang-dtd:hover{background:color-mix(in srgb,var(--tech-dtd) 12%,transparent);border-color:var(--tech-dtd);color:var(--tech-dtd)}.btn-lang-sql{border-color:color-mix(in srgb,var(--tech-sql) 40%,transparent);color:var(--tech-sql)}.btn-lang-sql:hover{background:color-mix(in srgb,var(--tech-sql) 12%,transparent);border-color:var(--tech-sql);color:var(--tech-sql)}.btn-lang-mysql{border-color:color-mix(in srgb,var(--tech-mysql) 40%,transparent);color:var(--tech-mysql)}.btn-lang-mysql:hover{background:color-mix(in srgb,var(--tech-mysql) 12%,transparent);border-color:var(--tech-mysql);color:var(--tech-mysql)}.margin-top-large{margin-top:1.5rem !important}.vertical-links{display:flex;flex-direction:column;gap:.75rem}.btn-alt{background:rgba(16,185,129,.1) !important;color:var(--color-accent) !important;border:1px solid rgba(16,185,129,.3) !important}.btn-alt:hover{background:rgba(16,185,129,.2) !important;border-color:var(--color-accent) !important}.sidebar-hint{font-size:.75rem;color:var(--color-text-muted,#94a3b8);margin-top:-.25rem;margin-bottom:.5rem;opacity:.7;line-height:1.4}.sidebar-note{font-size:.85rem;color:var(--color-text);margin-bottom:1rem;line-height:1.5;opacity:.9}.sidebar-tags{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem;& li { background: var(--color-surface-brighter); border: 1px solid var(--color-border); padding: 0.35rem 0.65rem; border-radius: 6px; font-size: 0.8rem; font-family: var(--font-mono); color: var(--color-text-heading); }}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.metric-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem;background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:8px}.metric-val{font-size:1.15rem;font-weight:700;color:var(--color-accent);font-family:var(--font-mono)}.metric-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-top:.25rem}.iframe-container{width:100%;height:75vh;max-height:700px;background-color:var(--color-surface);border-radius:0 0 12px 12px;overflow:hidden;@media(max-width:768px){height: 100%; max-height: none; border-radius: 0; flex: 1;}}.preview-iframe{width:100%;height:100%;border:none;display:block}.sidebar-separator{height:1px;background:var(--color-border);margin:1.5rem 0;width:100%;@media(max-width:1023px){display: none;}}.sidebar-sub-section{display:flex;flex-direction:column;gap:.5rem;@media(max-width:1023px){display: contents;}}.btn-playground-launch{width:100%;justify-content:center;gap:.75rem;@media(max-width:1023px){width: auto; flex: 0 0 auto;}}.sql-console-body{padding:0 !important;display:flex;flex-direction:column}.sql-console-layout.dark-ide-theme{display:flex;flex-direction:column;height:80vh;min-height:500px;background:#000;border-radius:0 0 12px 12px}.sql-console-editor-panel{position:relative;height:250px;flex-shrink:0;display:flex;background:#050505}#sql-query-input{flex:1;width:100%;padding:1rem;background:0 0;color:#e5e7eb;font-family:var(--font-mono);font-size:.95rem;line-height:1.5;border:none;resize:none;outline:none}#sql-query-input:focus{outline:none !important;box-shadow:none !important;border:none !important}.sql-console-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.4rem 1rem;background:#0a0a0a;border-top:1px solid #1f1f1f;border-bottom:1px solid #1f1f1f}.toolbar-left,.toolbar-right{display:flex;gap:.75rem;align-items:center}.sql-console-results-panel{flex:1;min-height:0;display:flex;flex-direction:column;background:#000}.sql-results-container{flex:1;padding:0;overflow:auto}.sql-status{font-size:.75rem;padding:.2rem .6rem;border-radius:4px;font-family:var(--font-mono)}.status-loading{color:#9ca3af}.status-success{color:#10b981}.status-error{color:#ef4444}.sql-results-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.8rem;color:#d1d5db}.sql-results-table th,.sql-results-table td{padding:.4rem .8rem;border-bottom:1px solid #1f1f1f;text-align:left;white-space:nowrap}.sql-results-table th{background:#0a0a0a;font-weight:600;color:#fff;position:sticky;top:0;z-index:10;border-bottom:2px solid #374151}.sql-results-table tr:nth-child(even){background:#050505}.sql-results-table tr:hover{background:#111827}.sql-empty-state,.sql-error{padding:2rem;text-align:center;color:#6b7280;font-size:.9rem}.sql-error{color:#ef4444;text-align:left;background:rgba(239,68,68,.1);padding:1rem}.academic-sidebar{display:flex;flex-direction:column;gap:1.5rem}.academic-meta-card{background:var(--color-surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1)}.academic-meta-title{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--color-accent);text-transform:uppercase;margin-bottom:1.25rem;letter-spacing:.05em;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.academic-meta-list{display:flex;flex-direction:column;gap:.85rem}.academic-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;border-bottom:1px dashed var(--color-border);padding-bottom:.5rem;&:last-child { border-bottom:none; padding-bottom:0; } & .meta-label { color:var(--color-text); font-weight:500; } & .meta-value { color:var(--color-text-heading); font-weight:600; text-align:right; &.monospace { font-family:var(--font-mono); font-size:0.8rem; } }}.academic-actions{display:flex;flex-direction:column;gap:.75rem}.btn-academic{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.85rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent;&.btn-primary-academic { background: var(--color-accent); color: #ffffff; &:hover { background: var(--color-text-heading); color: var(--color-bg-base); box-shadow: 0 0 15px var(--color-glow); transform: translateY(-2px); } } &.btn-secondary-academic { background: var(--color-glow); color: var(--color-text-heading); border-color: var(--color-border); &:hover { background: var(--color-border); border-color: var(--color-accent); transform: translateY(-2px); } }}.citation-widget{margin-top:.5rem}.citation-tabs{display:flex;background:var(--color-glow);border-radius:6px 6px 0 0;padding:.25rem .25rem 0;border-bottom:1px solid var(--color-border)}.citation-tab-btn{background:0 0;border:none;color:var(--color-text);padding:.5rem .75rem;font-family:var(--font-mono);font-size:.75rem;cursor:pointer;border-radius:4px 4px 0 0;transition:all .2s ease;&:hover { color:var(--color-text-heading); background:var(--color-glow); } &.active { color:var(--color-accent); background:var(--color-border); font-weight:700; }}.citation-box{background:var(--color-bg-base);border-radius:0 0 6px 6px;padding:1rem;position:relative;border:1px solid var(--color-border);border-top:none}.citation-pane{display:none;font-size:.78rem;line-height:1.5;color:var(--color-text);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;&.active { display: block; }}.btn-copy-citation{display:inline-flex;align-items:center;justify-content:center;background:var(--color-glow);border:1px solid var(--color-border);color:var(--color-text-heading);font-size:.75rem;font-weight:600;padding:.4rem .8rem;border-radius:4px;cursor:pointer;margin-top:.75rem;transition:all .2s ease;&:hover { background:var(--color-accent); color:#ffffff; border-color:var(--color-accent); } &.copied { background:#10b981; color:#ffffff; border-color:#10b981; }}.academic-explorer{display:flex;flex-direction:column}.explorer-tabs-container{overflow-x:auto;border-bottom:1px solid var(--color-border);margin-bottom:.5rem;scrollbar-width:none;&::-webkit-scrollbar { display:none; }}.explorer-tabs{display:flex;gap:.5rem;padding-bottom:1px;min-width:max-content}.academic-tab-btn{background:0 0;border:none;border-bottom:2px solid transparent;color:var(--color-text);padding:.75rem 1.25rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;&:hover { color:var(--color-text-heading); border-bottom-color:var(--color-border); } &.active { color:var(--color-accent); border-bottom-color:var(--color-accent); text-shadow:0 0 10px var(--color-glow); }}.explorer-content{padding:.5rem 0;min-height:400px}.academic-tab-pane{display:none;animation:fadeIn .4s ease-out forwards;&.active { display: block; } & h2 { font-size: 1.5rem; font-weight: 700; color: var(--color-text-heading); margin-bottom: 1.25rem; border-left: 3px solid var(--color-accent); padding-left: 0.75rem; } & h3 { font-size: 1.15rem; font-weight: 600; color: var(--color-text-heading); margin: 1.5rem 0 0.75rem; } & p { color: var(--color-text); font-size: 0.95rem; line-height: 1.65; margin-bottom: 1.25rem; }}@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}#modal-pdf-viewer>.custom-modal-content{width:75vw;height:90vh;max-width:900px}.preview-iframe{width:100%;height:100%;border:none}.inline-svg-diagram{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:zoom-in;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;transition:transform .3s ease,border-color .3s ease;margin-bottom:1.5rem}.inline-svg-diagram:hover{border-color:var(--color-accent)}.inline-svg-diagram:hover .diagram-wrapper img{transform:scale(1.02)}.diagram-wrapper{background:#fff;padding:1rem;border-radius:8px;width:100%;max-width:750px;height:auto;min-height:250px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.1)}.diagram-wrapper img{max-width:100%;max-height:500px;object-fit:contain;transition:transform .3s ease}.diagram-caption{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text);margin-top:1.25rem;text-align:center}.custom-modal-content.lightbox-modal-content{background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:12px;width:95vw !important;height:90vh !important;max-width:950px !important;max-height:85vh !important;display:flex;flex-direction:column;position:relative;overflow:hidden}.lightbox-header{padding:1rem 1.5rem !important;border-bottom:1px solid var(--color-border);position:relative;display:flex;align-items:center;gap:1rem}.lightbox-title{font-size:1.05rem;font-weight:700;color:var(--color-text-heading);flex:1;line-height:1.2}.lightbox-body{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg-base);padding:2.5rem;overflow:hidden;cursor:pointer}.lightbox-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;background:#fff;padding:1.5rem;box-shadow:0 20px 50px rgba(0,0,0,.25);transition:transform .2s ease}.lightbox-image:hover{transform:scale(1.015)}.lightbox-zoom-controls{position:absolute;bottom:1.5rem;right:1.5rem;display:flex;gap:.5rem;z-index:100}.lightbox-zoom-btn{width:2.5rem;height:2.5rem;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-heading);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;backdrop-filter:blur(8px)}.lightbox-zoom-btn:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.code-tab-container{margin-top:0 !important;margin-bottom:1.5rem !important;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:var(--color-bg-base)}.code-tabs-header{display:flex;background:var(--color-glow);border-bottom:1px solid var(--color-border);padding:0 .5rem}.code-tab-btn{background:0 0;border:none;color:var(--color-text);padding:.75rem 1rem;font-family:var(--font-mono);font-size:.75rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease;&:hover { color:var(--color-text-heading); } &.active { color:var(--color-accent); border-bottom-color:var(--color-accent); font-weight:700; }}.code-tab-content{padding:1.75rem !important;& pre { margin: 0; border-radius: 0; border: none; font-size: 0.8rem; }}.code-pane{display:none;&.active { display: block; }}.academic-table-container{overflow-x:auto;margin:1.5rem 0;border:1px solid var(--color-border);border-radius:8px}.academic-data-table{width:100%;border-collapse:collapse;text-align:left;font-size:.85rem;& th { background: var(--color-glow); color: var(--color-text-heading); font-weight: 600; padding: 0.75rem 1rem; border-bottom: 1px solid var(--color-border); } & td { padding: 0.75rem 1rem; border-bottom: 1px dashed var(--color-border); color: var(--color-text); &.highlight { color: var(--color-accent); font-weight: 600; } } & tr:last-child td { border-bottom: none; } & tr:nth-child(even) { background: var(--color-glow); }}