/* ════════════════════════════════════════════════
   기찬에듀 기찬수학 — Shared Design System CSS
   keychanedu.keychanmath
════════════════════════════════════════════════ */

@font-face { font-family:'BM Dohyeon'; src:url('fonts/BMDOHYEON_otf.otf') format('opentype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Nanum Gothic'; src:url('fonts/NanumGothic.otf') format('opentype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Nanum Gothic'; src:url('fonts/NanumGothicBold.otf') format('opentype'); font-weight:700; font-display:swap; }
@font-face { font-family:'Nanum Gothic'; src:url('fonts/NanumGothicExtraBold.otf') format('opentype'); font-weight:800; font-display:swap; }

:root {
  --navy:       #1B1464;
  --navy-dark:  #120E46;
  --navy-mid:   #1E1880;
  --navy-light: #2A1F96;
  --red:        #E30613;
  --red-light:  #FF4D57;
  --orange:     #FF9F43;
  --yellow:     #FECA57;
  --n-100: #FFFFFF; --n-99: #F7F7F8; --n-95: #F4F4F5; --n-90: #E8E8EA;
  --n-80: #DBDCDF;  --n-70: #C2C4C8; --n-50: #9899A2; --n-40: #70737C;
  --n-30: #55565F;  --n-20: #37383C; --n-10: #17171A;
  --border:       rgba(112,115,124,.22);
  --border-strong:rgba(112,115,124,.44);
  --shadow-1: 0 1px 4px rgba(0,0,0,.06);
  --shadow-2: 0 2px 8px rgba(0,0,0,.08);
  --shadow-3: 0 4px 16px rgba(0,0,0,.12);
  --shadow-4: 0 8px 32px rgba(0,0,0,.16);
  --r-xs:4px; --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-full:9999px;
  --font-d:'BM Dohyeon','Apple SD Gothic Neo',sans-serif;
  --font-b:'Nanum Gothic','Apple SD Gothic Neo',sans-serif;
  --nav-h:64px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-b);color:var(--n-10);background:#fff;-webkit-font-smoothing:antialiased;line-height:1.6;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,textarea,select{font-family:inherit;}

/* ─ Container ─ */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px;}

/* ════════════════════════════════════════
   NAVIGATION
════════════════════════════════════════ */
.site-nav {
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
.site-nav.scrolled{box-shadow:var(--shadow-2);}
.nav-inner{display:flex;align-items:center;height:100%;gap:8px;}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:8px;}
.nav-logo img{height:36px;width:auto;object-fit:contain;}
.nav-logo-text{font-family:var(--font-d);font-size:20px;color:var(--navy);line-height:1;}
.nav-links{display:flex;align-items:center;flex:1;}
.nav-item{position:relative;}
.nav-item>a,.nav-item>button{
  display:flex;align-items:center;gap:4px;
  padding:8px 14px;font-size:14px;font-weight:700;
  color:var(--n-20);white-space:nowrap;
  background:none;border:none;cursor:pointer;
  transition:color .2s;
  font-family:var(--font-b);
}
.nav-item>a:hover,.nav-item>button:hover,.nav-item>a.active{color:var(--navy);}
.nav-item>a.active{font-weight:800;}
.nav-chevron{width:14px;height:14px;transition:transform .2s;}
.nav-item:hover .nav-chevron{transform:rotate(180deg);}
.nav-drop{
  position:absolute;top:calc(100% + 6px);left:0;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);
  padding:6px 0;box-shadow:var(--shadow-3);min-width:148px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .18s;z-index:200;
}
.nav-item:hover .nav-drop{opacity:1;visibility:visible;transform:translateY(0);}
.nav-drop a{
  display:block;padding:8px 16px;font-size:13px;font-weight:700;
  color:var(--n-30);transition:background .12s,color .12s;
  white-space:nowrap;
}
.nav-drop a:hover{background:var(--n-99);color:var(--navy);}
.nav-cta-btn{
  margin-left:auto;
  background:var(--navy);color:#fff;
  padding:9px 20px;border-radius:var(--r-sm);
  font-size:13px;font-weight:800;
  transition:background .2s,transform .15s;
  flex-shrink:0;white-space:nowrap;
}
.nav-cta-btn:hover{background:var(--navy-dark);transform:translateY(-1px);}
.nav-ham{display:none;margin-left:auto;padding:8px;color:var(--n-20);flex-shrink:0;}
.nav-ham svg{display:block;}

/* Mobile menu */
.mob-menu{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;
  background:#fff;z-index:999;overflow-y:auto;
  padding:8px 0 32px;
}
.mob-menu.open{display:block;}
.mob-group{border-bottom:1px solid var(--border);}
.mob-group-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;font-size:15px;font-weight:700;color:var(--n-10);
  width:100%;cursor:pointer;
}
.mob-group-head svg{transition:transform .2s;}
.mob-group.open .mob-group-head svg{transform:rotate(180deg);}
.mob-sub{display:none;padding:0 24px 12px 32px;}
.mob-group.open .mob-sub{display:block;}
.mob-sub a,.mob-link a{
  display:block;padding:8px 0;font-size:14px;font-weight:700;color:var(--n-40);
}
.mob-link{border-bottom:1px solid var(--border);}
.mob-link a{padding:14px 24px;color:var(--n-10);}
.mob-cta{padding:16px 24px;}
.mob-cta a{
  display:block;text-align:center;background:var(--navy);color:#fff;
  padding:14px;border-radius:var(--r-sm);font-size:15px;font-weight:800;
}

@media(max-width:900px){
  .nav-links,.nav-cta-btn{display:none;}
  .nav-ham{display:flex;}
}

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
.site-footer{background:var(--navy-dark);color:rgba(255,255,255,.65);padding:64px 0 32px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.footer-logo img{height:32px;filter:brightness(0) invert(1);opacity:.9;}
.footer-logo-text{font-family:var(--font-d);font-size:20px;color:#fff;}
.footer-brand p{font-size:13px;line-height:2;}
.footer-col h4{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px;}
.footer-col ul li{margin-bottom:8px;}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,.6);transition:color .2s;}
.footer-col ul li a:hover{color:#fff;}
.footer-phone{font-family:var(--font-d);font-size:24px;color:#fff;margin-bottom:6px;}
.footer-links-row{display:flex;gap:12px;margin-top:12px;}
.footer-links-row a{
  display:flex;align-items:center;gap:6px;
  padding:7px 14px;border:1px solid rgba(255,255,255,.2);border-radius:var(--r-sm);
  font-size:12px;font-weight:700;color:rgba(255,255,255,.7);
  transition:border-color .2s,color .2s;
}
.footer-links-row a:hover{border-color:rgba(255,255,255,.5);color:#fff;}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  font-size:12px;color:rgba(255,255,255,.3);
}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr;gap:32px;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
}

/* ════════════════════════════════════════
   BUTTONS
════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;border-radius:var(--r-sm);
  font-family:var(--font-b);font-size:15px;font-weight:800;
  transition:all .2s;cursor:pointer;white-space:nowrap;border:none;
}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy-dark);transform:translateY(-1px);box-shadow:var(--shadow-3);}
.btn-red{background:var(--red);color:#fff;}
.btn-red:hover{background:var(--red-light);transform:translateY(-1px);box-shadow:var(--shadow-3);}
.btn-outline-white{border:2px solid rgba(255,255,255,.6);color:#fff;background:transparent;}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:#fff;}
.btn-outline{border:2px solid var(--navy);color:var(--navy);background:transparent;}
.btn-outline:hover{background:var(--navy);color:#fff;}
.btn-sm{padding:9px 18px;font-size:13px;}
.btn-lg{padding:17px 36px;font-size:17px;}

/* ════════════════════════════════════════
   CARDS
════════════════════════════════════════ */
.card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--shadow-2);overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-3);}
.card-thumb{width:100%;aspect-ratio:16/9;background:var(--n-95);overflow:hidden;position:relative;}
.card-thumb img{width:100%;height:100%;object-fit:cover;}
.card-body{padding:20px 24px 24px;}
.card-tag{
  display:inline-block;font-size:11px;font-weight:800;letter-spacing:.04em;
  padding:3px 10px;border-radius:var(--r-full);margin-bottom:10px;
}
.tag-navy{background:rgba(27,20,100,.08);color:var(--navy);}
.tag-red{background:rgba(227,6,19,.08);color:var(--red);}
.tag-orange{background:rgba(255,159,67,.12);color:#c06000;}
.tag-green{background:rgba(0,191,64,.1);color:#007a29;}
.card-title{font-size:16px;font-weight:800;color:var(--n-10);margin-bottom:6px;line-height:1.4;}
.card-desc{font-size:14px;color:var(--n-40);line-height:1.65;}
.card-meta{display:flex;align-items:center;gap:12px;margin-top:14px;font-size:12px;color:var(--n-50);}

/* ════════════════════════════════════════
   SECTION
════════════════════════════════════════ */
.section{padding:80px 0;}
.section-sm{padding:56px 0;}
.section-dark{background:var(--navy);color:#fff;}
.section-subtle{background:var(--n-99);}
.section-label{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:10px;}
.section-title{font-family:var(--font-d);font-size:36px;line-height:1.3;color:var(--navy);margin-bottom:12px;}
.section-dark .section-title{color:#fff;}
.section-subtitle{font-size:16px;color:var(--n-40);max-width:540px;line-height:1.75;}
.section-dark .section-subtitle{color:rgba(255,255,255,.6);}
.section-header{margin-bottom:48px;}
.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:48px;flex-wrap:wrap;}

/* ════════════════════════════════════════
   PAGE HERO (inner pages)
════════════════════════════════════════ */
.page-hero{
  background:var(--navy);
  padding:calc(var(--nav-h) + 48px) 0 56px;
}
.page-hero-eyebrow{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:12px;}
.page-hero-title{font-family:var(--font-d);font-size:40px;color:#fff;margin-bottom:12px;}
.page-hero-desc{font-size:15px;color:rgba(255,255,255,.65);max-width:520px;line-height:1.75;}
.breadcrumb{display:flex;align-items:center;gap:6px;margin-top:24px;font-size:12px;color:rgba(255,255,255,.35);}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .2s;}
.breadcrumb a:hover{color:rgba(255,255,255,.7);}
.breadcrumb-sep{color:rgba(255,255,255,.2);}

/* ════════════════════════════════════════
   TABS
════════════════════════════════════════ */
.tab-bar{display:flex;border-bottom:2px solid var(--border);margin-bottom:32px;gap:0;overflow-x:auto;}
.tab-item{
  padding:12px 20px;font-size:14px;font-weight:700;color:var(--n-50);
  border-bottom:2px solid transparent;margin-bottom:-2px;
  cursor:pointer;white-space:nowrap;transition:all .18s;
}
.tab-item:hover{color:var(--navy);}
.tab-item.active{color:var(--navy);border-bottom-color:var(--navy);}
.tab-pane{display:none;}
.tab-pane.active{display:block;}

/* ════════════════════════════════════════
   BOARD / LIST
════════════════════════════════════════ */
.board-table{width:100%;border-top:2px solid var(--navy);}
.board-row{
  display:grid;
  grid-template-columns:60px 1fr 90px 100px;
  align-items:center;gap:0;
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  transition:background .12s;cursor:pointer;
}
.board-row:hover{background:var(--n-99);}
.board-row.pinned{background:#f0f0f9;}
.board-row.header{
  background:var(--n-95);padding:10px 16px;cursor:default;
  font-size:12px;font-weight:800;color:var(--n-50);letter-spacing:.04em;
}
.board-row.header:hover{background:var(--n-95);}
.board-num{text-align:center;font-size:13px;color:var(--n-50);}
.board-title{font-size:14px;font-weight:700;color:var(--n-10);display:flex;align-items:center;gap:8px;}
.board-title-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.board-author{font-size:13px;color:var(--n-50);text-align:center;}
.board-date{font-size:13px;color:var(--n-50);text-align:right;}
.pin-badge{
  display:inline-block;font-size:10px;font-weight:800;
  background:var(--navy);color:#fff;padding:2px 7px;border-radius:var(--r-full);
  flex-shrink:0;
}
.new-badge{
  display:inline-block;font-size:10px;font-weight:800;
  background:var(--red);color:#fff;padding:2px 6px;border-radius:var(--r-full);flex-shrink:0;
}

/* ════════════════════════════════════════
   PAGINATION
════════════════════════════════════════ */
.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin-top:32px;}
.page-btn{
  width:36px;height:36px;border-radius:var(--r-sm);
  font-size:13px;font-weight:700;color:var(--n-40);
  transition:all .15s;
}
.page-btn:hover{background:var(--n-95);color:var(--navy);}
.page-btn.active{background:var(--navy);color:#fff;}
.page-btn.arrow{font-size:16px;color:var(--n-50);}

/* ════════════════════════════════════════
   FORM
════════════════════════════════════════ */
.form-group{margin-bottom:20px;}
.form-label{display:block;font-size:13px;font-weight:800;color:var(--n-20);margin-bottom:7px;}
.form-label .req{color:var(--red);margin-left:2px;}
.form-control{
  width:100%;padding:12px 14px;
  border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:14px;font-family:var(--font-b);color:var(--n-10);
  background:#fff;transition:border-color .18s,box-shadow .18s;
  outline:none;
}
.form-control:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,20,100,.1);}
.form-control::placeholder{color:var(--n-70);}
textarea.form-control{resize:vertical;min-height:120px;line-height:1.6;}
select.form-control{cursor:pointer;}
.form-hint{font-size:12px;color:var(--n-50);margin-top:5px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ════════════════════════════════════════
   GRID HELPERS
════════════════════════════════════════ */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .section-title{font-size:30px;}
  .page-hero-title{font-size:32px;}
}
@media(max-width:640px){
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr;}
  .section{padding:56px 0;}
  .section-title{font-size:26px;}
  .container{padding:0 16px;}
  .board-row{grid-template-columns:1fr 80px;}
  .board-num,.board-author{display:none;}
  .form-row{grid-template-columns:1fr;}
}
