:root{--bg:#0b0c10;--card:#101217;--text:#ffffff;--muted:#c8c8d0;--accent:#9bf00b;--accent-2:#badaff;--accent-3:#0b0c10;--accent-4:#ff2bd6;--border:#2a2e3b;--lilac:#1a1b24}
[data-theme="light"]{--bg:#ffffff;--card:#f7f9ff;--text:#0f172a;--muted:#475569;--accent:#78d80d;--accent-2:#263238;--accent-3:#f4f4f5;--accent-4:#db2777;--border:#d3ddf7;--lilac:#eadcff}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
h1,h2,h3{font-family:"Archivo Black",Impact,Haettenschweiler,'Arial Narrow Bold',sans-serif;margin:0 0 .5rem;line-height:1.08;letter-spacing:.2px}
/* Header */
.site-header{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#000;box-shadow:0 2px 0 #9bf00b inset;border-bottom:1px solid var(--border);z-index:20}
.brand{display:flex;gap:.75rem;align-items:center}
.brand-mark{width:40px;height:40px;border-radius:8px;background:var(--accent);display:grid;place-items:center;color:#000;font-weight:800}
.brand-text span{display:block;color:var(--muted);font-size:.8rem}
.nav{display:flex;gap:.4rem;flex-wrap:wrap}
.nav-btn{border:1px solid var(--border);background:transparent;color:var(--text);padding:.35rem .6rem;border-radius:.6rem;cursor:pointer}
.nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.actions{display:flex;gap:.5rem}
#print,#toggle-theme{border:1px solid var(--border);background:transparent;color:var(--text);padding:.35rem .6rem;border-radius:.6rem;cursor:pointer}
/* Layout */
main{max-width:1240px;margin:0 auto;padding:1rem}
.section{padding:2rem 0}
.section.alt{background:linear-gradient(180deg,rgba(155,240,11,.05),rgba(155,240,11,.02));border:1px solid var(--border);border-left:none;border-right:none}
.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:1.25rem;align-items:center}
.lead{color:var(--muted)}
.hero-cta{display:flex;gap:.75rem;margin-top:1rem}
.button{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--border);color:var(--text);padding:.55rem .85rem;border-radius:.75rem;text-decoration:none}
.button.primary{background:linear-gradient(135deg,var(--accent),#d0ff7f);border:none;color:#000;box-shadow:0 8px 24px rgba(155,240,11,.35)}
.chips{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.chip{padding:.35rem .6rem;border:1px dashed var(--accent-2);border-radius:999px;color:var(--accent-2);background:rgba(139,92,246,.1)}
/* Cards */
.grid.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:stretch;justify-items:stretch}
.card{background:linear-gradient(155deg,rgba(255,255,255,.05),rgba(255,255,255,.01));border:1px solid var(--border);border-radius:1rem;padding:1rem;box-shadow:0 12px 28px rgba(0,0,0,.35);display:flex;flex-direction:column;gap:.5rem;min-height:260px}
.card.big{grid-column:span 2}
.card-actions{margin-top:auto}
.evidence{cursor:pointer;border:1px solid var(--accent);background:rgba(155,240,11,.12);color:#c6ff00;padding:.45rem .7rem;border-radius:.6rem}
.evidence:hover{background:rgba(155,240,11,.2)}
/* Trio panels */
.grid.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;align-items:stretch}
.panel{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--border);border-radius:1rem;padding:1rem;min-height:220px}
.bullets{margin:.2rem 0 .2rem 1.1rem}
/* Mutante-like banner blocks */
.banner{padding:3rem 1rem;border-top:8px solid var(--accent);border-bottom:8px solid var(--accent)}
.banner.lilac{background:var(--lilac);color:var(--text)}
.banner.neon{background:linear-gradient(180deg,rgba(155,240,11,.15),rgba(155,240,11,.05))}
.banner .display{font-size:3rem}
.banner .dek{font-size:1.1rem;max-width:900px;color:var(--text)}
.kicker{color:var(--accent);font-weight:800;letter-spacing:.1em;margin-bottom:.25rem}
.hed{font-size:2.25rem;margin-bottom:.5rem}
/* Inline explanations */
blockquote{color:var(--text)}
.apa{color:var(--muted)}
.comment{color:var(--muted);font-style:italic;margin-top:.25rem}
/* Rubric */
.rubric{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem}
.rubric-col{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1rem}
.evidence-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.evidence-item{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1rem}
.evidence-item .meta{color:var(--muted);font-size:.9rem}
/* Footer & modal */
.site-footer{padding:1.5rem 1rem;color:var(--muted);text-align:center;border-top:1px solid var(--border);background:linear-gradient(180deg,transparent,rgba(34,211,238,.08))}
.modal{max-width:740px;border:none;border-radius:1rem;background:var(--card);color:var(--text);padding:0}
.modal::backdrop{background:rgba(0,0,0,.6)}
.modal-content{padding:1rem;border:1px solid var(--border);border-radius:1rem}
.modal .close{float:right;border:none;background:transparent;color:var(--muted);font-size:1.5rem;cursor:pointer}
blockquote{margin:.5rem 0;padding:.5rem 1rem;border-left:3px solid var(--accent);background:rgba(255,255,255,.02)}
/* Text & links */
a{color:#7aa2f7;text-decoration:underline dotted}
a:hover{color:#9bbcfb}
a:visited{color:#6b7bb7}
.url{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;word-break:break-all;background:rgba(255,255,255,.04);padding:.1rem .3rem;border-radius:.25rem}
/* Particle field */
.particles{position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(2px 2px at 10% 20%,rgba(155,240,11,.5),transparent 60%),radial-gradient(2px 2px at 80% 30%,rgba(139,92,246,.35),transparent 60%),radial-gradient(2px 2px at 40% 70%,rgba(59,130,246,.35),transparent 60%),radial-gradient(2px 2px at 60% 50%,rgba(236,72,153,.35),transparent 60%)}
/* Subtle graphic/interactive parallax spotlight */
.parallax{position:fixed;inset:auto 0 0 0;height:160px;pointer-events:none;z-index:0;background:radial-gradient(120px 120px at var(--mx,50%) var(--my,50%),rgba(155,240,11,.18),transparent 60%)}
main{position:relative;z-index:1}
/* Fancy cards and panels hover effect */
.card,.panel{transition:transform .2s ease, box-shadow .2s ease}
.card:hover,.panel:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(155,240,11,.15)}
/* Horizontal scrollers: one-line rows */
.hscroll{display:flex;gap:1rem;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;padding-bottom:.5rem;-webkit-overflow-scrolling:touch;mask-image:linear-gradient(to right,transparent 0,black 24px,black calc(100% - 24px),transparent 100%);overscroll-behavior-x:contain;touch-action:pan-x pan-y pinch-zoom}
.hscroll > .card,.hscroll > .panel{flex:0 0 360px;scroll-snap-align:start}
.cards-row .card.big{flex-basis:540px}
.hscroll:active{cursor:grabbing}
.hscroll::-webkit-scrollbar{height:8px}
.hscroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}
/* Section-specific icons for h3 via CSS variable */
.section{position:relative}
.section h3{position:relative;padding-left:1.85rem;display:flex;align-items:center}
.section h3::before{content:var(--icon,"✦");position:absolute;left:0;top:50%;transform:translateY(-50%);width:1.4rem;height:1.4rem;border-radius:.45rem;display:grid;place-items:center;font-size:.9rem;line-height:1;background:radial-gradient(60% 60% at 30% 30%,rgba(155,240,11,.5),rgba(155,240,11,.12));box-shadow:0 0 0 1px var(--border) inset,0 10px 22px rgba(155,240,11,.25);color:#0b0c10}
/* Assign icons per top-level section */
#principios{--icon:"🌟"}
#modelo{--icon:"📚"}
#docente{--icon:"👩‍🏫"}
#ambientes{--icon:"🏫"}
#orientaciones{--icon:"🧭"}
#evaluacion{--icon:"📈"}
#convivencia{--icon:"🤝"}
#rubrica{--icon:"📋"}
#referencias{--icon:"🔗"}
/* Animated separators between sections */
.section::after{content:"";display:block;height:8px;margin:1.75rem 0 0;border-radius:999px;background:repeating-linear-gradient(90deg,rgba(155,240,11,.35) 0 12px,transparent 12px 24px);filter:drop-shadow(0 2px 6px rgba(155,240,11,.28));animation:sepSlide 16s linear infinite;background-size:24px 100%}
.section.neon::after{background:repeating-linear-gradient(90deg,rgba(155,240,11,.5) 0 12px,rgba(11,12,16,.0) 12px 24px)}
@keyframes sepSlide{to{background-position:240px 0}}
/* Hover micro-interactions on h3 */
.section h3:hover::before{box-shadow:0 0 0 1px var(--accent) inset,0 12px 20px rgba(155,240,11,.4),0 0 18px rgba(155,240,11,.35);transform:translateY(-50%) rotate(-6deg) scale(1.04)}
.section h3:hover{color:var(--accent)}
/* Scroll progress bar */
#scroll-progress{position:fixed;top:0;left:0;height:4px;width:0;background:linear-gradient(90deg,var(--accent),#d0ff7f);z-index:50;box-shadow:0 0 12px rgba(155,240,11,.65)}
/* Print styles */
@media print{
  :root{--bg:#ffffff;--text:#000;--card:#fff;--border:#bbb}
  body{background:#fff;color:#000}
  .no-print,.site-header{display:none !important}
  main{max-width:100%;padding:0}
  .section{padding:16mm 12mm}
  .grid.cards{grid-template-columns:repeat(3,1fr)}
  .grid.trio{grid-template-columns:repeat(3,1fr)}
  .rubric{grid-template-columns:repeat(3,1fr)}
  .break-before{break-before:page}
}
/* Responsive */
@media (max-width: 980px){
  .hero{grid-template-columns:1fr}
  .grid.cards{grid-template-columns:1fr}
  .grid.trio{grid-template-columns:1fr}
  .evidence-list{grid-template-columns:1fr}
  .rubric{grid-template-columns:1fr}
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}


