/* ============ 페이지별 컴포넌트 ============ */

/* HERO (home) */
.hero{padding:150px 0 70px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:radial-gradient(900px 500px at 82% -8%,rgba(63,134,255,.16),transparent 60%),radial-gradient(700px 420px at 6% 18%,rgba(22,165,116,.12),transparent 60%)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.55rem)}
.hero h1 .hl{color:var(--sky);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.32em;background:rgba(245,166,35,.32);z-index:-1;border-radius:4px}
.hero .lead{margin-top:22px;font-size:1.14rem;color:var(--ink-soft);max-width:30em;font-weight:500}
.first-badge{display:inline-flex;align-items:center;gap:9px;margin-bottom:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);padding:8px 15px 8px 9px;border-radius:99px;font-size:.86rem;font-weight:700;color:var(--ink)}
.first-badge b{background:var(--grow);color:#fff;padding:3px 9px;border-radius:99px;font-size:.74rem;letter-spacing:.04em}
.hero-cta{display:flex;gap:13px;margin-top:34px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:46px;flex-wrap:wrap}
.hero-stats .s b{display:block;font-size:1.85rem;font-weight:800;color:var(--ink);line-height:1}
.hero-stats .s span{font-size:.84rem;color:var(--ink-soft);font-weight:600}
.journey-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:26px;position:relative}
.journey-card .jc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.journey-card .jc-top span{font-size:.78rem;font-weight:700;color:var(--ink-soft);letter-spacing:.06em}
.jc-dot{display:flex;gap:5px}.jc-dot i{width:8px;height:8px;border-radius:50%;background:var(--line)}.jc-dot i:first-child{background:var(--grow)}
.path{position:relative;padding-left:8px}
.path-step{display:flex;gap:16px;align-items:flex-start;padding:13px 0;position:relative}
.path-step:not(:last-child)::before{content:"";position:absolute;left:18px;top:42px;bottom:-13px;width:2px;background:linear-gradient(var(--sky),var(--grow))}
.ps-num{width:38px;height:38px;border-radius:11px;flex:none;display:grid;place-items:center;font-weight:800;color:#fff;font-size:.95rem;box-shadow:var(--shadow-sm);z-index:1}
.ps-1{background:linear-gradient(135deg,#f5a623,#f57b23)}.ps-2{background:linear-gradient(135deg,#3f86ff,#2563d8)}
.ps-3{background:linear-gradient(135deg,#16a574,#0f8a60)}.ps-4{background:linear-gradient(135deg,#7c5cff,#5b3fd8)}
.ps-body b{display:block;font-size:1rem;font-weight:700}.ps-body span{font-size:.83rem;color:var(--ink-soft)}
.float-tag{position:absolute;background:#fff;border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-sm);padding:11px 15px;font-size:.83rem;font-weight:700;display:flex;align-items:center;gap:9px}
.float-tag i{width:9px;height:9px;border-radius:50%}
.ft-1{top:-18px;right:-14px;animation:float 5s ease-in-out infinite}
.ft-2{bottom:34px;left:-26px;animation:float 6s ease-in-out infinite .8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* TRUST */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--mist);padding:22px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;font-size:.92rem;color:var(--ink-soft);font-weight:600}
.trust-inner b{color:var(--ink)}.trust-inner .sep{width:5px;height:5px;border-radius:50%;background:var(--line)}

/* STEPS (journey) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;position:relative;overflow:hidden;transition:.25s}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.step::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.step.s1::before{background:#f5a623}.step.s2::before{background:#2563d8}.step.s3::before{background:#16a574}.step.s4::before{background:#7c5cff}
.step .stage{font-size:.74rem;font-weight:800;letter-spacing:.1em;color:var(--ink-soft)}
.step .sicon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;margin:10px 0 14px}
.step.s1 .sicon{background:linear-gradient(135deg,#f5a623,#f57b23)}.step.s2 .sicon{background:linear-gradient(135deg,#3f86ff,#2563d8)}
.step.s3 .sicon{background:linear-gradient(135deg,#16a574,#0f8a60)}.step.s4 .sicon{background:linear-gradient(135deg,#7c5cff,#5b3fd8)}
.step h3{font-size:1.2rem}.step p{font-size:.9rem;color:var(--ink-soft);margin-top:8px}
.step .mini{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}
.step .mini span{font-size:.74rem;background:var(--mist);border:1px solid var(--line);padding:4px 9px;border-radius:7px;font-weight:600;color:var(--ink-soft)}

/* SYSTEM page detail */
.stage-block{display:grid;grid-template-columns:300px 1fr;gap:34px;align-items:start;padding:30px;background:#fff;border:1px solid var(--line);border-radius:20px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.stage-block:last-child{margin-bottom:0}
.stage-side{position:sticky;top:96px}
.stage-side .num{font-size:3.2rem;font-weight:800;line-height:1;letter-spacing:-.04em}
.stage-side h2{font-size:1.7rem;margin:10px 0 8px}
.stage-side p{color:var(--ink-soft);font-size:.95rem}
.stage-side .bar{height:6px;border-radius:3px;width:56px;margin-top:16px}
.b1{background:#f5a623;color:#f5a623}.b2{background:#2563d8;color:#2563d8}.b3{background:#16a574;color:#16a574}.b4{background:#7c5cff;color:#7c5cff}
.t1{color:#c87a14}.t2{color:#2563d8}.t3{color:#16a574}.t4{color:#5b3fd8}
.stage-progs{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* AUDIENCE tabs */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.tab{display:flex;align-items:center;gap:11px;padding:14px 22px;border-radius:14px;background:#fff;border:1.5px solid var(--line);cursor:pointer;font-weight:700;font-size:1rem;color:var(--ink-soft);transition:.2s}
.tab .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;flex:none}
.tab.active{border-color:var(--ink);color:var(--ink);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.tab[data-t="student"] .ic{background:linear-gradient(135deg,#3f86ff,#2563d8)}
.tab[data-t="teacher"] .ic{background:linear-gradient(135deg,#16a574,#0f8a60)}
.tab[data-t="parent"] .ic{background:linear-gradient(135deg,#f5a623,#f57b23)}
.panel{display:none;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm);animation:fade .4s ease}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 34px}
.panel h3{font-size:1.45rem;margin-bottom:6px}
.panel .ptag{color:var(--sky);font-weight:700;font-size:.9rem}
.panel ul{list-style:none;margin-top:8px}
.panel li{display:flex;gap:11px;padding:9px 0;border-bottom:1px dashed var(--line);font-weight:500;color:var(--ink-soft)}
.panel li:last-child{border-bottom:0}.panel li b{color:var(--ink);font-weight:700}

/* PROGRAMS */
.prog-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.fbtn{padding:9px 17px;border-radius:99px;border:1.5px solid var(--line);background:#fff;font-weight:700;font-size:.88rem;color:var(--ink-soft);cursor:pointer;transition:.2s}
.fbtn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;transition:.25s;display:flex;flex-direction:column}
.pcard:hover{box-shadow:var(--shadow);transform:translateY(-5px);border-color:transparent}
.pcard .cat{display:inline-flex;align-self:flex-start;font-size:.72rem;font-weight:800;letter-spacing:.04em;padding:5px 11px;border-radius:7px;margin-bottom:14px}
.cat-explore{background:#fef3e0;color:#c87a14}.cat-admission{background:var(--sky-pale);color:var(--sky)}
.cat-study{background:var(--grow-pale);color:var(--grow)}.cat-capacity{background:#efeaff;color:#5b3fd8}
.pcard h3{font-size:1.18rem}.pcard .who{font-size:.82rem;color:var(--ink-soft);font-weight:600;margin-top:5px}
.pcard .desc{font-size:.92rem;color:var(--ink-soft);margin-top:12px;flex:1}
.pcard .meta{margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);display:flex;justify-content:space-between;align-items:center;font-size:.82rem}
.pcard .when{color:var(--ink-soft);font-weight:600;display:flex;align-items:center;gap:6px}
.pcard .budget{font-size:.78rem;color:var(--ink-soft);margin-top:10px;font-weight:600}

/* SPOTLIGHT */
.spotlight{background:linear-gradient(135deg,var(--ink),#16244f);color:#fff;border-radius:28px;padding:50px;position:relative;overflow:hidden}
.spotlight::before{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(63,134,255,.4),transparent 70%)}
.spotlight::after{content:"";position:absolute;left:-60px;bottom:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(22,165,116,.35),transparent 70%)}
.spot-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;position:relative;z-index:1}
.spotlight .new-pill{display:inline-block;margin-bottom:16px;font-size:.76rem;padding:5px 12px}
.spotlight h2{font-size:clamp(1.7rem,3vw,2.3rem)}.spotlight p{color:#c8d4f0;margin-top:16px;font-size:1.05rem}
.spot-feats{list-style:none;margin-top:24px;display:grid;gap:11px}
.spot-feats li{display:flex;gap:11px;align-items:flex-start;font-weight:500;color:#dde6fa}
.spot-feats .check{background:rgba(22,165,116,.25);color:#5fe0b0}
.spot-info{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:24px;backdrop-filter:blur(8px)}
.spot-info .row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:.92rem}
.spot-info .row:last-child{border-bottom:0}.spot-info .row span{color:#aebbdc}.spot-info .row b{font-weight:700}

/* CALENDAR */
.cal{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:#fff;box-shadow:var(--shadow-sm)}
table.roadmap{border-collapse:collapse;width:100%;min-width:880px;font-size:.84rem}
table.roadmap th,table.roadmap td{padding:11px 7px;text-align:center;border-bottom:1px solid var(--line)}
table.roadmap thead th{background:var(--ink);color:#fff;font-weight:700;position:sticky;top:0}
table.roadmap .grp{font-weight:800;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:.1em;font-size:.78rem;color:#fff;padding:0;width:34px}
.grp-explore{background:#f5a623}.grp-admission{background:#2563d8}.grp-study{background:#16a574}.grp-capacity{background:#7c5cff}
table.roadmap td.name{text-align:left;font-weight:600;white-space:nowrap;padding-left:14px;color:var(--ink)}
.bar2{height:14px;border-radius:7px;background:var(--line);opacity:.25}.bar2.on{opacity:1}
.bar2.b-explore{background:#f5a623}.bar2.b-admission{background:#2563d8}.bar2.b-study{background:#16a574}.bar2.b-capacity{background:#7c5cff}
.legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:20px;font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.legend i{display:inline-block;width:14px;height:14px;border-radius:4px;margin-right:6px;vertical-align:-2px}

/* RESULTS */
.results-dark{background:var(--ink);color:#fff;padding:80px 0}
.results-dark .sec-head h2{color:#fff}.results-dark .sec-head p{color:#bccaeb}
.results-dark .eyebrow{color:#7fb0ff}.results-dark .eyebrow::before{background:var(--grow)}
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.res{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:28px 24px}
.res b{font-size:2.6rem;font-weight:800;line-height:1;background:linear-gradient(120deg,#7fb0ff,#5fe0b0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.res .u{font-size:1.1rem;font-weight:700;margin-left:3px;-webkit-text-fill-color:#fff;color:#fff}
.res p{color:#c8d4f0;margin-top:9px;font-size:.92rem;font-weight:500}
.res-note{margin-top:26px;text-align:center;color:#8696bf;font-size:.84rem}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.detail-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-sm)}
.detail-card h3{font-size:1.15rem;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.detail-card .dot{width:10px;height:10px;border-radius:50%;flex:none}
.detail-card table{width:100%;border-collapse:collapse;font-size:.9rem}
.detail-card td{padding:9px 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.detail-card tr:last-child td{border-bottom:0}.detail-card td:last-child{text-align:right;font-weight:700;color:var(--ink)}
.eval-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.eval{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px}
.eval h4{font-size:1.05rem;margin-bottom:8px;display:flex;gap:9px;align-items:center}
.eval p{font-size:.92rem;color:var(--ink-soft)}
.eval .tagx{font-size:.7rem;font-weight:800;padding:3px 9px;border-radius:6px;background:var(--grow-pale);color:var(--grow)}
.eval.improve .tagx{background:#fef3e0;color:#c87a14}

/* NOTICE + APPLY */
.split{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.notice-box,.apply-box{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.box-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.box-head h3{font-size:1.3rem}.box-head a{font-size:.85rem;font-weight:700;color:var(--sky)}
.notice-list{list-style:none}
.notice-list li{display:flex;gap:14px;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}
.notice-list li:last-child{border-bottom:0}
.notice-list .tag{font-size:.7rem;font-weight:800;padding:4px 9px;border-radius:6px;flex:none}
.tag-open{background:var(--grow-pale);color:var(--grow)}.tag-info{background:var(--sky-pale);color:var(--sky)}.tag-event{background:#fef3e0;color:#c87a14}
.notice-list .nt{font-weight:600;font-size:.94rem;flex:1}.notice-list .nd{font-size:.8rem;color:var(--ink-soft);font-weight:600;flex:none}
.apply-box{background:linear-gradient(150deg,var(--sky-pale),#fff)}
.apply-step{display:flex;gap:15px;padding:13px 0}
.apply-step .n{width:30px;height:30px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.9rem;flex:none}
.apply-step b{display:block;font-size:1rem}.apply-step span{font-size:.86rem;color:var(--ink-soft)}
.apply-box .btn{width:100%;justify-content:center;margin-top:18px}

/* FORM */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-pale)}
.field textarea{resize:vertical;min-height:96px}
.form-note{font-size:.82rem;color:var(--ink-soft);margin-top:4px}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:.2s}
.faq-item.open{box-shadow:var(--shadow-sm);border-color:var(--sky)}
.faq-q{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:700;gap:16px}
.faq-q .qmark{color:var(--sky);font-weight:800;flex:none}
.faq-q .chev{transition:.3s;flex:none;color:var(--ink-soft)}
.faq-item.open .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft)}
.faq-a div{padding:0 24px 22px 56px;font-weight:500}

/* CTA */
.cta-band{background:linear-gradient(135deg,var(--sky),var(--ink));color:#fff;border-radius:30px;padding:60px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% -20%,rgba(255,255,255,.18),transparent)}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.6rem);position:relative}
.cta-band p{color:#dbe5fb;margin:16px auto 0;max-width:36em;font-size:1.1rem;position:relative}
.cta-band .hero-cta{justify-content:center;position:relative}
.cta-band .btn-primary{background:#fff;color:var(--ink)}.cta-band .btn-primary:hover{background:var(--sun);color:var(--ink)}
.cta-band .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}.cta-band .btn-ghost:hover{border-color:#fff;color:#fff}

/* responsive */
@media(max-width:980px){
  .hero-grid,.spot-grid,.split,.panel-grid,.stage-block,.detail-grid,.eval-grid,.form-row{grid-template-columns:1fr}
  .steps,.prog-grid,.res-grid,.stage-progs{grid-template-columns:1fr 1fr}
  .hero-visual{order:-1}.ft-1,.ft-2{display:none}
  .spotlight,.cta-band{padding:36px}
  .stage-side{position:static}
}
@media(max-width:560px){.steps,.prog-grid,.res-grid,.stage-progs{grid-template-columns:1fr}}

/* ===== JOURNEY FLOW (지원체계 페이지 상단 여정) ===== */
.journey-wrap{background:linear-gradient(180deg,#fff, var(--mist));border:1px solid var(--line);border-radius:28px;padding:48px 40px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.journey-wrap::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(640px 300px at 85% -10%,rgba(63,134,255,.12),transparent 60%),radial-gradient(520px 280px at 5% 110%,rgba(22,165,116,.1),transparent 60%)}
.journey-head{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;margin-bottom:38px;flex-wrap:wrap;gap:12px}
.journey-head .jt{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.15rem;color:var(--ink)}
.journey-head .jt .pin{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--sky),var(--ink))}
.journey-head .jdots{display:flex;gap:7px}
.journey-head .jdots i{width:9px;height:9px;border-radius:50%;background:var(--line)}
.journey-head .jdots i:first-child{background:var(--grow);width:24px;border-radius:6px}

/* horizontal flow (desktop) */
.flow{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.flow-step{position:relative;padding:0 14px;text-align:center}
/* connector line behind nodes */
.flow-step::before{content:"";position:absolute;top:32px;left:-50%;width:100%;height:3px;background:linear-gradient(90deg,var(--from),var(--to));z-index:0}
.flow-step:first-child::before{display:none}
.flow-node{position:relative;z-index:1;width:64px;height:64px;border-radius:18px;margin:0 auto 20px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.4rem;box-shadow:var(--shadow-sm);transition:.3s}
.flow-step:hover .flow-node{transform:translateY(-6px) scale(1.05)}
.flow-icon{position:absolute;right:-6px;bottom:-6px;width:28px;height:28px;border-radius:9px;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.fn-1{background:linear-gradient(135deg,#f5a623,#f57b23)}
.fn-2{background:linear-gradient(135deg,#3f86ff,#2563d8)}
.fn-3{background:linear-gradient(135deg,#16a574,#0f8a60)}
.fn-4{background:linear-gradient(135deg,#7c5cff,#5b3fd8)}
.flow-step h3{font-size:1.18rem;margin-bottom:7px}
.flow-step p{font-size:.9rem;color:var(--ink-soft);line-height:1.5}
.flow-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.flow-tags span{font-size:.72rem;background:#fff;border:1px solid var(--line);padding:4px 10px;border-radius:99px;font-weight:600;color:var(--ink-soft)}
.flow-arrow{position:absolute;top:24px;right:-9px;z-index:2;color:#c3ccde}

@media(max-width:820px){
  .journey-wrap{padding:32px 22px}
  .flow{grid-template-columns:1fr;gap:0}
  .flow-step{display:grid;grid-template-columns:64px 1fr;gap:18px;text-align:left;padding:18px 0;align-items:start}
  .flow-step::before{display:none}
  .flow-node{margin:0}
  .flow-arrow{display:none}
  .flow-tags{justify-content:flex-start}
  /* vertical connector */
  .flow-step:not(:last-child)::after{content:"";position:absolute;left:31px;top:70px;bottom:-18px;width:3px;background:var(--line);z-index:0}
}
