:root{
  --graduation-bg:#f5efe6;
  --graduation-surface:rgba(255,253,249,0.96);
  --graduation-surface-strong:#fffdf8;
  --graduation-text:#14212b;
  --graduation-muted:#5f6974;
  --graduation-accent:#0f766e;
  --graduation-accent-soft:#edf7f5;
  --graduation-warn:#b45309;
  --graduation-warn-soft:#fff1db;
  --graduation-danger:#b91c1c;
  --graduation-danger-soft:#fee2e2;
  --graduation-border:rgba(20,33,43,0.08);
  --graduation-shadow:0 24px 60px rgba(15,23,42,0.14);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;
  font-family:"Plus Jakarta Sans", sans-serif;
  background:
    radial-gradient(circle at top, rgba(15,118,110,0.12), transparent 38%),
    linear-gradient(180deg, #fbf7f0 0%, var(--graduation-bg) 100%);
  color:var(--graduation-text);
}

body.graduation-has-fireworks{overflow-x:hidden}

a{color:inherit}

.graduation-fireworks{
  position:fixed;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:3;
}

.graduation-firework,
.graduation-firework::before,
.graduation-firework::after{
  --firework-size:0.42rem;
  --firework-final-size:16rem;
  --firework-spark-a:#f59e0b;
  --firework-spark-b:#f43f5e;
  --firework-spark-c:#22c55e;
  --firework-spark-d:#38bdf8;
  --firework-spark-e:#facc15;
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:var(--firework-size);
  height:var(--firework-size);
  transform:translate(-50%, -50%);
  border-radius:50%;
  background:
    radial-gradient(circle, var(--firework-spark-a) 0 0.16rem, transparent 0.18rem) 50% 0%,
    radial-gradient(circle, var(--firework-spark-b) 0 0.16rem, transparent 0.18rem) 100% 50%,
    radial-gradient(circle, var(--firework-spark-c) 0 0.16rem, transparent 0.18rem) 50% 100%,
    radial-gradient(circle, var(--firework-spark-d) 0 0.16rem, transparent 0.18rem) 0% 50%,
    radial-gradient(circle, var(--firework-spark-e) 0 0.15rem, transparent 0.17rem) 84% 16%,
    radial-gradient(circle, #ffffff 0 0.12rem, transparent 0.14rem) 16% 22%,
    radial-gradient(circle, #fb7185 0 0.15rem, transparent 0.17rem) 84% 84%,
    radial-gradient(circle, #a855f7 0 0.15rem, transparent 0.17rem) 16% 84%,
    radial-gradient(circle, #fef08a 0 0.14rem, transparent 0.16rem) 26% 10%,
    radial-gradient(circle, #67e8f9 0 0.14rem, transparent 0.16rem) 74% 10%,
    radial-gradient(circle, #4ade80 0 0.14rem, transparent 0.16rem) 8% 72%,
    radial-gradient(circle, #fda4af 0 0.14rem, transparent 0.16rem) 28% 94%,
    radial-gradient(circle, #fdba74 0 0.14rem, transparent 0.16rem) 92% 72%,
    radial-gradient(circle, #c4b5fd 0 0.14rem, transparent 0.16rem) 72% 94%;
  background-size:var(--firework-size) var(--firework-size);
  background-repeat:no-repeat;
  opacity:0;
  filter:drop-shadow(0 0 8px rgba(255,255,255,0.28)) saturate(1.18);
  animation:graduation-firework 2s cubic-bezier(.17,.67,.2,1) 1 forwards;
}

.graduation-firework::before{
  transform:translate(-50%, -50%) scale(0.85) rotate(25deg);
}

.graduation-firework::after{
  transform:translate(-50%, -50%) scale(1.15) rotate(-28deg);
}

.graduation-firework-one{top:50%;left:50%;--firework-final-size:16rem;animation-delay:0s}
.graduation-firework-two{top:50%;left:50%;--firework-final-size:13rem;--firework-spark-a:#fb7185;--firework-spark-b:#facc15;--firework-spark-c:#38bdf8;--firework-spark-d:#c084fc;--firework-spark-e:#4ade80;animation-delay:.22s}
.graduation-firework-three{top:50%;left:50%;--firework-final-size:18rem;--firework-spark-a:#f97316;--firework-spark-b:#22c55e;--firework-spark-c:#60a5fa;--firework-spark-d:#fde047;--firework-spark-e:#f472b6;animation-delay:.44s}
.graduation-firework-four{top:50%;left:50%;--firework-final-size:11.5rem;--firework-spark-a:#ffffff;--firework-spark-b:#f59e0b;--firework-spark-c:#34d399;--firework-spark-d:#38bdf8;--firework-spark-e:#fb7185;animation-delay:.68s}

.graduation-page,
.graduation-shell{position:relative;z-index:1}

.graduation-page{
  width:min(100%, 480px);
  margin:0 auto;
  padding:24px 18px 42px;
}

.graduation-shell{
  display:grid;
  gap:18px;
}

.graduation-card,
.graduation-status-card,
.graduation-note{
  border-radius:28px;
  border:1px solid var(--graduation-border);
  background:var(--graduation-surface);
  box-shadow:var(--graduation-shadow);
}

.graduation-logo-wrap{
  width:92px;
  height:92px;
  margin:0 auto 16px;
  padding:8px;
  border-radius:28px;
  background:linear-gradient(135deg, rgba(15,118,110,0.14), rgba(217,119,6,0.18));
}

.graduation-logo,
.graduation-logo-fallback{
  width:100%;
  height:100%;
  display:block;
  border-radius:22px;
}

.graduation-logo{object-fit:cover;background:#fff}

.graduation-logo-fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, #0f766e, #d97706);
  color:#fff;
  font-family:"Cormorant Garamond", serif;
  font-size:2.5rem;
  font-weight:700;
}

.graduation-panel-title,
.graduation-card h2,
.graduation-status-card h2{
  margin:0;
  font-family:"Cormorant Garamond", serif;
  letter-spacing:-0.02em;
}

.graduation-panel-head{
  display:flex;
  align-items:center;
  gap:16px;
}

.graduation-panel-head-compact{align-items:flex-start}

.graduation-logo-wrap-inline{
  flex:0 0 92px;
  margin:0;
}

.graduation-panel-copy{min-width:0;flex:1}

.graduation-panel-title{font-size:2.15rem;line-height:0.96}

.graduation-panel-text{
  margin:10px 0 0;
  color:var(--graduation-muted);
  line-height:1.7;
  font-size:0.95rem;
}

.graduation-panel-divider{
  height:1px;
  margin:18px 0;
  background:linear-gradient(90deg, rgba(15,118,110,0.24), rgba(217,119,6,0.18), transparent);
}

.graduation-card,
.graduation-status-card,
.graduation-note{padding:22px 20px}

.graduation-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  color:var(--graduation-accent);
  font-size:0.78rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.graduation-card p,
.graduation-note p{margin:10px 0 0;color:var(--graduation-muted);line-height:1.75}

.graduation-form{display:grid;gap:14px;margin-top:18px}

.graduation-label{
  display:grid;
  gap:8px;
  color:var(--graduation-text);
  font-size:0.95rem;
  font-weight:700;
}

.graduation-input{
  width:100%;
  min-height:56px;
  padding:0 16px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,0.12);
  background:var(--graduation-surface-strong);
  color:var(--graduation-text);
  font-size:1rem;
  font-weight:600;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.graduation-input:focus{
  outline:none;
  border-color:rgba(15,118,110,0.42);
  box-shadow:0 0 0 4px rgba(15,118,110,0.12);
}

.graduation-button,
.graduation-link-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:54px;
  padding:0 18px;
  border:none;
  border-radius:18px;
  background:linear-gradient(135deg, #0f766e, #d97706);
  color:#fff;
  font-size:0.98rem;
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
  box-shadow:0 18px 34px rgba(15,118,110,0.24);
}

.graduation-link-button.secondary{
  background:#fff;
  color:var(--graduation-text);
  border:1px solid rgba(15,23,42,0.10);
  box-shadow:none;
}

.graduation-actions{display:grid;gap:10px;margin-top:18px}

.graduation-student-grid{
  display:grid;
  gap:12px;
  margin-top:18px;
}

.graduation-field{
  padding:14px 15px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(15,23,42,0.06);
}

.graduation-field-label{
  display:block;
  margin-bottom:6px;
  color:var(--graduation-muted);
  font-size:0.78rem;
  font-weight:800;
  letter-spacing:0.06em;
  text-transform:uppercase;
}

.graduation-field-value{
  display:block;
  font-size:1rem;
  line-height:1.55;
  font-weight:700;
  color:var(--graduation-text);
  word-break:break-word;
}

.graduation-meta-chip{
  display:inline-flex;
  align-items:center;
  margin-top:14px;
  padding:8px 12px;
  border-radius:999px;
  background:var(--graduation-accent-soft);
  color:var(--graduation-accent);
  font-size:0.84rem;
  font-weight:800;
}

.graduation-status-card h2{font-size:2rem;line-height:0.98}

.graduation-status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  margin-top:16px;
  padding:16px 18px;
  border-radius:22px;
  font-size:1.2rem;
  font-weight:900;
  letter-spacing:0.02em;
}

.status-passed{background:var(--graduation-accent-soft);color:var(--graduation-accent)}
.status-failed{background:var(--graduation-danger-soft);color:var(--graduation-danger)}

.graduation-note{
  background:var(--graduation-warn-soft);
  border-color:rgba(180,83,9,0.14);
}

.graduation-note strong{display:block;font-size:1rem;color:#7c2d12}

.graduation-note.error{
  background:#fff4f4;
  border-color:rgba(185,28,28,0.14);
}

.graduation-note.error strong{color:var(--graduation-danger)}

.graduation-footnote{
  text-align:center;
  color:var(--graduation-muted);
  font-size:0.84rem;
  line-height:1.7;
}

@keyframes graduation-firework{
  0%{
    opacity:0;
    width:var(--firework-size);
    height:var(--firework-size);
    filter:drop-shadow(0 0 2px rgba(255,255,255,0.1)) brightness(1);
  }
  10%{
    opacity:1;
  }
  38%{
    opacity:1;
    filter:drop-shadow(0 0 14px rgba(255,255,255,0.36)) brightness(1.2);
  }
  100%{
    opacity:0;
    width:var(--firework-final-size);
    height:var(--firework-final-size);
    filter:drop-shadow(0 0 4px rgba(255,255,255,0.08)) brightness(1.08);
  }
}

@media(min-width:720px){
  .graduation-page{width:min(100%, 760px);padding:34px 22px 60px}
  .graduation-logo-wrap{width:112px;height:112px;margin-bottom:20px}
  .graduation-logo-wrap-inline{flex-basis:112px;margin:0}
  .graduation-panel-title{font-size:3rem}
  .graduation-student-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .graduation-field[data-span="full"]{grid-column:1 / -1}
  .graduation-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:420px){
  .graduation-panel-head{align-items:flex-start}
  .graduation-panel-title{font-size:1.9rem}
  .graduation-logo-wrap-inline{flex-basis:82px;width:82px;height:82px}
  .graduation-firework,
  .graduation-firework::before,
  .graduation-firework::after{--firework-final-size:12rem}
}

@media(prefers-reduced-motion:reduce){
  .graduation-fireworks{display:none}
}