/* ============================================================
   KDD 2026 Tutorial — Discovery, Validation & Editing of LLM Mechanisms
   Styled to harmonize with yinhanhe123.github.io (Academic Pages / Minimal Mistakes)
   ============================================================ */
:root{
  --bg:#fff;
  --bg-soft:#f8f9fa;
  --surface:#fff;
  --surface-2:#f2f3f5;
  --line:#eaecee;
  --line-strong:#dcdfe2;
  --ink:#3b4042;          /* headings — theme dark-gray */
  --ink-soft:#52595e;     /* body text */
  --ink-dim:#8a9197;      /* muted */
  --brand:#2f7f93;        /* theme link/info teal */
  --brand-deep:#246575;   /* hover */
  --brand-2:#4a9cb0;      /* lighter teal for gradients */
  --gray:#7a8288;         /* theme primary gray */
  --masthead-h:58px;
  --radius:12px;
  --maxw:1000px;
  --serif:Georgia,Times,serif;
  --sans:-apple-system,".SFNSText-Regular","San Francisco","Roboto","Segoe UI","Helvetica Neue","Lucida Grande",Arial,sans-serif;
  --mono:Monaco,Consolas,"Lucida Console",monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--masthead-h) + 50px)}
body{
  margin:0;background:var(--bg);color:var(--ink-soft);
  font-family:var(--sans);font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:var(--brand)}
a:hover{color:var(--brand-deep)}
img{max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- SITE MASTHEAD (mirrors personal site) ---------- */
.site-masthead{
  position:fixed;top:0;left:0;width:100%;height:var(--masthead-h);z-index:30;
  background:#fff;border-bottom:1px solid var(--line-strong);
}
.site-masthead__inner{
  max-width:1100px;margin:0 auto;height:100%;padding:0 22px;
  display:flex;align-items:center;gap:22px;
}
.site-name{font-weight:700;font-size:16.5px;color:var(--gray);text-decoration:none;white-space:nowrap;padding-right:.5em}
.site-name:hover{color:var(--ink)}
.site-nav{display:flex;gap:18px;flex-wrap:wrap;margin-left:auto}
.site-nav a{color:var(--gray);text-decoration:none;font-size:15px;transition:.15s}
.site-nav a:hover{color:var(--ink)}
.site-nav a.current{color:var(--brand);font-weight:600}

/* ---------- SECTION SUB-NAV (in-page) ---------- */
.subnav{
  position:sticky;top:var(--masthead-h);z-index:20;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.subnav-inner{
  max-width:1100px;margin:0 auto;padding:0 22px;height:46px;
  display:flex;align-items:center;gap:2px;overflow-x:auto;
}
.subnav a{
  text-decoration:none;color:var(--ink-dim);font-size:13.5px;font-weight:600;
  padding:6px 11px;border-radius:7px;white-space:nowrap;transition:.15s;
}
.subnav a:hover{color:var(--ink);background:var(--surface-2)}
.subnav a.active{color:var(--brand);background:rgba(47,127,147,.09)}

/* push content below fixed masthead */
.page-top{height:var(--masthead-h)}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:
    radial-gradient(900px 360px at 78% -20%,rgba(47,127,147,.10),transparent 60%),
    radial-gradient(700px 320px at 8% -10%,rgba(122,130,136,.08),transparent 55%),
    #fff;}
.hero-bg{position:absolute;inset:0;opacity:.5;mask-image:linear-gradient(to bottom,#000 0%,transparent 94%)}
.hero-bg svg{width:100%;height:100%}
.hero-bg .circuit path{stroke-dasharray:6 8;opacity:.6;animation:flow 9s linear infinite}
.hero-bg .nodes circle{opacity:.7}
@keyframes flow{to{stroke-dashoffset:-140}}
@media (prefers-reduced-motion:reduce){.hero-bg .circuit path{animation:none}}

.hero-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:54px 22px 60px;text-align:center}
.venue-badge{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12.5px;font-weight:600;letter-spacing:.2px;color:var(--ink-soft);
  background:#fff;border:1px solid var(--line-strong);
  padding:7px 14px;border-radius:999px;margin-bottom:24px;
}
.venue-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 8px rgba(47,127,147,.5)}
.hero-title{
  font-family:var(--serif);font-weight:700;color:var(--ink);
  font-size:clamp(27px,4.8vw,46px);line-height:1.12;letter-spacing:-.3px;margin:0 0 14px;
}
.hero-subtitle{font-family:var(--serif);font-style:italic;color:var(--brand);font-size:clamp(16px,2.2vw,21px);margin:0 0 28px}
.authors{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:6px 22px;padding:0;margin:0 0 8px;font-size:16.5px;font-weight:600}
.authors a{color:var(--ink);text-decoration:none;border-bottom:1px solid transparent;transition:.15s}
.authors a:hover{border-color:var(--brand);color:var(--brand)}
.authors sup{color:var(--brand)}
.affil{color:var(--ink-dim);font-size:14px;margin:0 0 30px}
.affil sup{color:var(--brand)}

.hero-actions{display:flex;flex-wrap:wrap;gap:11px;justify-content:center}
.btn{
  display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-weight:600;font-size:14.5px;
  padding:11px 19px;border-radius:9px;border:1px solid transparent;transition:.15s;cursor:pointer;
}
.btn svg{flex:0 0 auto}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-primary:hover{background:var(--brand-deep);border-color:var(--brand-deep);color:#fff}
.btn-ghost{background:#fff;border-color:var(--line-strong);color:var(--ink-soft)}
.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn.is-disabled{opacity:.55;pointer-events:none}

/* ---------- SECTIONS ---------- */
.section{padding:62px 0;border-bottom:1px solid var(--line)}
.section-alt{background:var(--bg-soft)}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:700;color:var(--brand);margin:0 0 9px}
.section h2{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:clamp(24px,3.2vw,33px);letter-spacing:-.2px;margin:0 0 20px}
.prose{color:var(--ink-soft);max-width:760px}
.prose p{margin:0 0 15px}
.prose strong{color:var(--ink)}
.prose em{color:var(--brand);font-style:italic}
.lead{font-size:17px}

/* pills */
.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0 6px}
.pill{font-size:13px;font-weight:600;color:var(--ink-soft);background:#fff;border:1px solid var(--line-strong);padding:6px 12px;border-radius:999px}

/* three-part cards */
.threepart{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px}
.tp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 20px;position:relative;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,32,.03)}
.tp-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2))}
.tp-num{font-family:var(--mono);font-size:12.5px;color:var(--brand)}
.tp-card h3{font-family:var(--serif);font-size:21px;color:var(--ink);margin:7px 0 8px}
.tp-card p{color:var(--ink-soft);font-size:14.5px;margin:0;line-height:1.55}

/* ---------- TIMELINE ---------- */
.timeline{list-style:none;padding:0;margin:30px 0 0}
.tl-item{display:grid;grid-template-columns:112px 1fr;gap:20px;padding:0 0 8px;position:relative}
.tl-item:not(:last-child) .tl-body{padding-bottom:24px;border-bottom:1px solid var(--line)}
.tl-time{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding-top:2px}
.tl-tag{
  display:inline-grid;place-items:center;min-width:40px;height:40px;padding:0 8px;
  font-family:var(--serif);font-weight:700;font-size:17px;color:#fff;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));border-radius:10px;
}
.tl-dur{font-family:var(--mono);font-size:12px;color:var(--ink-dim)}
.tl-body h3{font-family:var(--serif);font-size:21px;color:var(--ink);margin:0 0 11px}
.tl-body ul{margin:0;padding-left:18px;color:var(--ink-soft)}
.tl-body li{margin:0 0 7px}
.tl-body li strong{color:var(--ink)}
.tl-break .tl-tag{background:var(--surface-2);color:var(--ink-dim);font-size:15px}
.tl-break .tl-body h3{font-size:14px;color:var(--ink-dim);font-family:var(--sans);font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.tl-break .tl-body{padding-bottom:16px}

/* ---------- AUDIENCE ---------- */
.audience-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:start;margin-top:8px}
.facts{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px 20px;box-shadow:0 1px 2px rgba(16,24,32,.03)}
.fact{display:flex;flex-direction:column;gap:2px;padding:14px 0;border-bottom:1px solid var(--line)}
.fact:last-child{border-bottom:0}
.fact-k{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--brand);font-weight:700}
.fact-v{color:var(--ink);font-size:14.5px;font-weight:500}

/* ---------- PRESENTERS ---------- */
.people{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px}
.person{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:0 1px 2px rgba(16,24,32,.03)}
.person-wide{grid-column:1 / -1}
.avatar{
  width:72px;height:72px;flex:0 0 auto;border-radius:12px;
  object-fit:cover;object-position:center top;display:block;
  background:var(--surface-2);border:1px solid var(--line-strong);
}
.avatar-lead{border:2px solid var(--brand);box-shadow:0 0 0 3px rgba(47,127,147,.12)}
.person-body h3{font-family:var(--serif);font-size:19px;color:var(--ink);margin:0 0 3px}
.person-role{color:var(--brand);font-size:13px;font-weight:600;margin:0 0 8px}
.person-body p:last-child{color:var(--ink-soft);font-size:14px;margin:0;line-height:1.55}
.corr-tag{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--brand);background:rgba(47,127,147,.1);border:1px solid rgba(47,127,147,.28);
  padding:3px 7px;border-radius:6px;vertical-align:middle;margin-left:8px}

/* ---------- MATERIALS ---------- */
.materials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
.mat-card{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:20px 18px;text-decoration:none;transition:.15s;min-height:124px;box-shadow:0 1px 2px rgba(16,24,32,.03)}
.mat-active:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:0 10px 22px -14px rgba(47,127,147,.5)}
.mat-soon{opacity:.7}
.mat-icon{font-size:24px}
.mat-title{font-weight:700;font-size:15.5px;color:var(--ink)}
.mat-meta{font-size:12.5px;color:var(--ink-dim)}
.note{color:var(--ink-dim);font-size:13.5px;margin-top:20px}

/* ---------- RELATED ---------- */
.related-list{display:grid;gap:14px;margin-top:28px}
.rel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 1px 2px rgba(16,24,32,.03)}
.rel-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px 16px;margin-bottom:6px}
.rel-head h3{font-family:var(--serif);font-size:19px;color:var(--ink);margin:0;flex:1 1 60%}
.rel-venue{font-family:var(--mono);font-size:12px;color:var(--brand);white-space:nowrap}
.rel-people{color:var(--ink-dim);font-size:13.5px;margin:0 0 11px}
.rel p:last-child{color:var(--ink-soft);font-size:14.5px;margin:0;line-height:1.55}
.rel p strong{color:var(--ink)}

/* ---------- REFERENCES ---------- */
.refs{margin:24px 0 0;padding-left:0;list-style:none;counter-reset:ref}
.refs li{counter-increment:ref;position:relative;padding:12px 0 12px 42px;border-bottom:1px solid var(--line);
  color:var(--ink-soft);font-size:14.5px;line-height:1.55}
.refs li::before{content:"[" counter(ref) "]";position:absolute;left:0;top:12px;font-family:var(--mono);font-size:12px;color:var(--brand);font-weight:500}
.refs em{color:var(--ink);font-style:italic}

/* ---------- CITE ---------- */
.cite-box{position:relative;margin-top:22px}
.cite-box pre{background:#f7f8f9;border:1px solid var(--line-strong);border-radius:var(--radius);padding:22px;overflow-x:auto;margin:0}
.cite-box code{font-family:var(--mono);font-size:13px;color:#3b4042;line-height:1.7}
.copy-btn{position:absolute;top:11px;right:11px;background:#fff;color:var(--ink-soft);
  border:1px solid var(--line-strong);border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:600;cursor:pointer;transition:.15s;font-family:var(--sans)}
.copy-btn:hover{background:var(--brand);border-color:var(--brand);color:#fff}

/* ---------- FOOTER ---------- */
.footer{padding:40px 0;background:var(--bg-soft);border-top:1px solid var(--line)}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;align-items:flex-start}
.footer-title{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--ink);margin:0 0 6px}
.footer-sub{color:var(--ink-dim);font-size:13.5px;margin:0;max-width:520px}
.footer-meta{color:var(--ink-dim);font-size:13px;text-align:right;margin:0;line-height:1.7}
.footer-meta a{color:var(--brand);text-decoration:none}
.footer-meta a:hover{text-decoration:underline}

/* ---------- RESPONSIVE ---------- */
@media (max-width:880px){
  .threepart,.people,.materials-grid{grid-template-columns:1fr}
  .materials-grid{grid-template-columns:1fr 1fr}
  .audience-grid{grid-template-columns:1fr}
  .site-name{font-size:15px}
  .site-nav{gap:13px}
}
@media (max-width:560px){
  .tl-item{grid-template-columns:50px 1fr;gap:12px}
  .materials-grid{grid-template-columns:1fr}
  .footer-meta{text-align:left}
  .rel-head h3{flex:1 1 100%}
  .site-name{display:none}
}
