/* ============================================================
   HANMAEK — inner page components
   Builds on css/styles.css (tokens, header, footer, .ph)
   ============================================================ */

/* ---------- PAGE BANNER (short hero) ---------- */
.page-banner{
  position:relative; min-height:56vh;
  display:flex; align-items:flex-end;
  color:var(--paper); background:var(--forest); overflow:hidden;
}
.page-banner .bnr-media{ position:absolute; inset:0; z-index:0; }
.page-banner .bnr-media img{ width:100%; height:100%; object-fit:cover; }
.page-banner .bnr-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,18,13,.62) 0%, rgba(10,18,13,.28) 42%, rgba(10,18,13,.82) 100%);
}
.page-banner .bnr-inner{
  position:relative; z-index:1; width:100%;
  padding-block:clamp(120px,18vh,200px) clamp(40px,6vh,64px);
}
.breadcrumb{
  font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(246,244,239,.62); display:flex; gap:.6em; align-items:center; margin-bottom:22px;
}
.breadcrumb a{ transition:color .25s; }
.breadcrumb a:hover{ color:#fff; }
.breadcrumb .sep{ color:var(--orange); }
.page-banner .eyebrow{ color:rgba(246,244,239,.7); }
.page-banner h1{
  font-family:var(--serif); font-weight:500; letter-spacing:-0.015em;
  font-size:clamp(38px,6vw,76px); line-height:1.02; margin-top:14px;
}
.page-banner .sub{ color:rgba(246,244,239,.78); font-size:clamp(16px,1.6vw,19px); margin-top:18px; max-width:52ch; line-height:1.6; text-wrap:pretty; }

/* ---------- SECTION HELPERS ---------- */
.isection{ padding-block:clamp(70px,9vw,140px); }
.isection.tint{ background:var(--paper-2); border-block:1px solid var(--line); }
.isection.dark{ background:var(--forest); color:var(--paper); }
.sec-head{ max-width:64ch; margin-bottom:clamp(34px,5vw,60px); }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head h2{ font-family:var(--serif); font-weight:500; letter-spacing:-0.012em; line-height:1.12; font-size:clamp(28px,4vw,52px); text-wrap:balance; }

/* ---------- PROSE ---------- */
.prose{ max-width:68ch; color:var(--ink-2); font-size:clamp(16px,1.45vw,19px); line-height:1.85; }
.prose p + p{ margin-top:1.3em; }
.prose strong{ color:var(--ink); font-weight:600; }
.dark .prose{ color:rgba(246,244,239,.74); }

/* ---------- CHAIRMAN ---------- */
.chairman .grid{ display:grid; grid-template-columns:minmax(0,.78fr) minmax(0,1.22fr); gap:clamp(34px,5vw,80px); align-items:start; }
.chairman .portrait{ position:relative; aspect-ratio:4/5; border:1px solid var(--line); }
.chairman .quote{ font-family:var(--serif); font-weight:500; font-size:clamp(24px,2.8vw,38px); line-height:1.3; letter-spacing:-0.015em; color:var(--ink); text-wrap:balance; }
.chairman .quote em{ font-style:normal; color:var(--orange-ink); }
.signature{ margin-top:36px; display:flex; flex-direction:column; gap:4px; }
.signature .role{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.signature .name{ font-size:20px; font-weight:600; letter-spacing:-0.01em; }

/* ---------- TIMELINE ---------- */
.timeline{ position:relative; border-left:1.5px solid var(--line); margin-left:6px; }
.tl-item{ position:relative; padding:0 0 clamp(36px,4.5vw,58px) clamp(28px,4vw,56px); }
.tl-item:last-child{ padding-bottom:0; }
.tl-item::before{
  content:""; position:absolute; left:-7px; top:4px; width:13px; height:13px; border-radius:50%;
  background:var(--paper); border:3px solid var(--orange);
}
.tl-item.now::before{ background:var(--orange); box-shadow:0 0 0 5px rgba(255,122,0,.18); }
.tl-item .yr{ font-family:var(--mono); font-size:clamp(16px,1.7vw,22px); font-weight:500; color:var(--orange-ink); letter-spacing:.02em; line-height:1; }
.tl-entries{ margin-top:18px; display:flex; flex-direction:column; gap:16px; }
.tl-entry{ display:grid; grid-template-columns:54px 1fr; gap:14px; align-items:start; }
.tl-entry .mo{ font-family:var(--mono); font-size:12px; font-weight:500; color:var(--ink-3); padding-top:2px; letter-spacing:.04em; }
.tl-entry p{ color:var(--ink); font-size:clamp(15px,1.4vw,17px); line-height:1.6; max-width:60ch; text-wrap:pretty; }
.tl-entry p .tag{ color:var(--orange-ink); font-weight:600; }
.tl-item.now .tl-entry p{ font-weight:500; }
@media (max-width:560px){ .tl-entry{ grid-template-columns:1fr; gap:4px; } }

/* ---------- VALUE CARDS ---------- */
.valgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.dark .valgrid{ background:rgba(246,244,239,.14); border-color:rgba(246,244,239,.14); }
.valcard{ background:var(--paper); padding:clamp(26px,3vw,40px); }
.dark .valcard{ background:var(--forest); }
.valcard .k{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--orange-ink); }
.dark .valcard .k{ color:var(--orange); }
.valcard .t{ font-size:clamp(19px,1.9vw,24px); font-weight:600; letter-spacing:-0.02em; margin-top:14px; }
.valcard .d{ color:var(--ink-2); font-size:15px; line-height:1.65; margin-top:12px; text-wrap:pretty; }
.dark .valcard .d{ color:rgba(246,244,239,.62); }

/* ---------- LINK-OUT TILES (e.g. subsidiaries) ---------- */
.tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
.tile{ position:relative; display:flex; flex-direction:column; min-height:300px; padding:28px; color:var(--paper); overflow:hidden; border-radius:2px; isolation:isolate; }
.tile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.tile::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(10,18,13,.2), rgba(10,18,13,.8)); }
.tile:hover img{ transform:scale(1.06); }
.tile .ko{ font-size:clamp(22px,2.4vw,30px); font-weight:600; letter-spacing:-0.02em; margin-top:auto; }
.tile .en{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:rgba(246,244,239,.7); margin-top:8px; }
.tile .fn{ color:rgba(246,244,239,.82); font-size:14.5px; line-height:1.55; margin-top:12px; text-wrap:pretty; }

/* ---------- CONTACT ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:start; }
.info-row{ display:flex; flex-direction:column; gap:6px; padding:22px 0; border-top:1px solid var(--line); }
.info-row:last-child{ border-bottom:1px solid var(--line); }
.info-row .lbl{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.info-row .val{ font-size:clamp(17px,1.6vw,20px); font-weight:500; letter-spacing:-0.01em; }
.map-ph{ aspect-ratio:4/3; border:1px solid var(--line); }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.field label{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.field input, .field textarea{ font-family:var(--sans); font-size:16px; color:var(--ink); background:var(--paper); border:1px solid var(--line); padding:14px 16px; border-radius:4px; transition:border-color .25s; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--orange); }

@media (max-width:900px){
  .chairman .grid{ grid-template-columns:1fr; }
  .chairman .portrait{ max-width:380px; }
  .valgrid{ grid-template-columns:1fr; }
  .tiles{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
}

/* ---------- SUBSIDIARY: big figures ---------- */
.figrow{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.dark .figrow{ background:rgba(246,244,239,.14); border-color:rgba(246,244,239,.14); }
.fig{ background:var(--paper); padding:clamp(26px,3vw,40px); }
.dark .fig{ background:var(--forest); }
.fig .n{ font-size:clamp(30px,4vw,52px); font-weight:600; letter-spacing:-0.03em; line-height:1; }
.fig .n .u{ font-size:.42em; color:var(--orange-ink); font-weight:500; margin-left:.12em; letter-spacing:0; }
.dark .fig .n .u{ color:var(--orange); }
.fig .l{ font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--ink-3); margin-top:14px; line-height:1.45; }
.dark .fig .l{ color:rgba(246,244,239,.6); }

/* ---------- SUBSIDIARY: spec list ---------- */
.specs{ border-top:1px solid var(--line); }
.spec{ display:grid; grid-template-columns:220px 1fr; gap:24px; padding:20px 0; border-bottom:1px solid var(--line); }
.spec dt{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); padding-top:3px; }
.spec dd{ font-size:clamp(16px,1.5vw,19px); color:var(--ink); line-height:1.55; letter-spacing:-0.01em; text-wrap:pretty; }
.spec dd .em{ color:var(--orange-ink); font-weight:600; }
@media (max-width:680px){ .spec{ grid-template-columns:1fr; gap:6px; } }

/* ---------- SUBSIDIARY: photo gallery ---------- */
.gal{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(10px,1.4vw,16px); }
.gal .g{ aspect-ratio:4/3; overflow:hidden; background:var(--paper-3); }
.gal .g img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.gal .g:hover img{ transform:scale(1.06); }
.gal .g.wide{ grid-column:span 2; aspect-ratio:auto; }
@media (max-width:760px){ .gal{ grid-template-columns:1fr 1fr; } .gal .g.wide{ grid-column:span 2; } }

/* subsidiary intro: two-column lead + body */
.subintro{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr); gap:clamp(34px,6vw,90px); align-items:start; }
@media (max-width:900px){ .subintro{ grid-template-columns:1fr; gap:28px; } }

/* ---------- NEWS / MEDIA ---------- */
.news-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.2vw,28px); }
@media (max-width:900px){ .news-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .news-grid{ grid-template-columns:1fr; } }
.news-thumb img{ width:100%; height:100%; object-fit:cover; }
.news-thumb.noimg{
  background:
    repeating-linear-gradient(135deg, rgba(255,122,0,.08) 0 2px, transparent 2px 11px),
    var(--paper-3);
  position:relative;
}
.news-thumb.noimg::after{
  content:"HANMAEK"; position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--mono); font-size:13px; letter-spacing:.18em; color:var(--ink-3);
}
.news-empty{ grid-column:1/-1; color:var(--ink-3); font-family:var(--mono); font-size:14px; padding:40px 0; }

.news-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:clamp(30px,4vw,48px); }
.news-toolbar .news-filters{ margin-bottom:0; }
.news-add-btn{
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
  font-size:14px; font-weight:600; letter-spacing:-0.01em;
  padding:10px 18px 10px 14px; border-radius:999px; cursor:pointer;
  color:var(--paper); background:var(--ink); border:1px solid var(--ink); transition:background .25s, transform .2s;
}
.news-add-btn:hover{ background:var(--orange-ink); border-color:var(--orange-ink); transform:translateY(-1px); }
.news-add-btn svg{ width:17px; height:17px; }

/* user-added article: delete badge */
.news-card.is-custom{ position:relative; }
.news-del{
  position:absolute; top:10px; right:10px; z-index:3; cursor:pointer;
  width:30px; height:30px; border-radius:50%; display:grid; place-items:center;
  font-size:13px; line-height:1; color:var(--ink); background:rgba(255,255,255,.92);
  border:1px solid var(--line); box-shadow:0 4px 14px -6px rgba(26,25,22,.5);
  opacity:0; transition:opacity .2s, background .2s, color .2s;
}
.news-card.is-custom:hover .news-del,
.news-del:focus-visible{ opacity:1; }
.news-del:hover{ background:var(--ink); color:var(--paper); }

/* add-article dialog */
.news-modal{ position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:24px;
  background:rgba(20,39,29,.46); backdrop-filter:blur(3px); }
.news-modal[hidden]{ display:none; }
.news-modal-card{ position:relative; width:min(520px,100%); max-height:90vh; overflow:auto;
  background:var(--paper); border:1px solid var(--line); border-radius:14px;
  padding:clamp(26px,4vw,38px); box-shadow:0 40px 80px -36px rgba(26,25,22,.5); }
.news-modal-card h3{ font-size:clamp(20px,2.2vw,24px); font-weight:650; letter-spacing:-0.02em; margin-bottom:22px; }
.news-modal-close{ position:absolute; top:16px; right:16px; width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center; cursor:pointer; font-size:14px; color:var(--ink-2);
  background:var(--paper-2); border:1px solid var(--line); transition:background .2s, color .2s; }
.news-modal-close:hover{ background:var(--ink); color:var(--paper); }
.nf{ display:flex; flex-direction:column; gap:7px; margin-bottom:16px; font-size:13px; font-weight:600;
  letter-spacing:.01em; color:var(--ink-2); }
.nf-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .nf-row{ grid-template-columns:1fr; } }
.nf input, .nf select{
  font:inherit; font-size:15px; font-weight:400; color:var(--ink);
  padding:11px 13px; border:1px solid var(--line); border-radius:8px; background:var(--paper);
  width:100%; transition:border-color .2s, box-shadow .2s;
}
.nf input:focus, .nf select:focus{ outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(255,122,0,.14); }
.nf-actions{ display:flex; justify-content:flex-end; gap:12px; margin-top:26px; }
.nf-btn{ font-size:14px; font-weight:600; letter-spacing:-0.01em; padding:11px 24px; border-radius:999px; cursor:pointer; transition:all .25s; }
.nf-btn.ghost{ background:transparent; color:var(--ink-2); border:1px solid var(--line); }
.nf-btn.ghost:hover{ border-color:var(--ink-3); color:var(--ink); }
.nf-btn.solid{ background:var(--ink); color:var(--paper); border:1px solid var(--ink); }
.nf-btn.solid:hover{ background:var(--orange-ink); border-color:var(--orange-ink); }

.news-filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:clamp(30px,4vw,48px); }
.news-filters button{
  font-size:14px; font-weight:500; letter-spacing:-0.01em; white-space:nowrap;
  padding:9px 18px; border-radius:999px; border:1px solid var(--line);
  color:var(--ink-2); background:var(--paper); transition:all .25s;
}
.news-filters button:hover{ border-color:var(--ink-3); color:var(--ink); }
.news-filters button.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---------- SOCIAL CONTRIBUTION ---------- */
.acts{ border-top:1px solid var(--line); }
.act{ display:grid; grid-template-columns:auto minmax(0,1fr) auto; gap:clamp(14px,2vw,28px); align-items:center; padding:22px 0; border-bottom:1px solid var(--line); }
.act .tag{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--orange-ink); border:1px solid var(--line); border-radius:999px; padding:6px 12px; white-space:nowrap; }
.act .txt{ font-size:clamp(15px,1.5vw,18.5px); color:var(--ink); line-height:1.5; letter-spacing:-0.01em; text-wrap:pretty; }
.act .lnk{ font-size:13px; font-weight:500; color:var(--orange-ink); white-space:nowrap; display:inline-flex; align-items:center; gap:.35em; }
.act .lnk:hover{ text-decoration:underline; }
@media (max-width:680px){
  .act{ grid-template-columns:1fr; gap:8px; align-items:flex-start; }
  .act .tag{ justify-self:start; }
}
.roles{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.role{ background:var(--paper); color:var(--ink); padding:22px 26px; font-size:clamp(15px,1.5vw,18px); font-weight:500; letter-spacing:-0.01em; display:flex; gap:13px; align-items:center; }
.role::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--orange); flex:none; }
@media (max-width:680px){ .roles{ grid-template-columns:1fr; } }

/* ---------- bilingual content blocks (for long static content) ---------- */
body[data-lang="ko"] .only-en{ display:none; }
body[data-lang="en"] .only-ko{ display:none; }

/* ---------- CHAIRMAN PROFILE (CV) ---------- */
.cv-head{ display:grid; grid-template-columns:minmax(0,.7fr) minmax(0,1.3fr); gap:clamp(34px,5vw,72px); align-items:start; }
.cv-portrait{ position:relative; aspect-ratio:4/5; border:1px solid var(--line); overflow:hidden; }
.cv-portrait img{ width:100%; height:100%; object-fit:cover; object-position:center 20%; }
.cv-id .nm{ font-family:var(--serif); font-weight:500; font-size:clamp(30px,4vw,52px); letter-spacing:-0.01em; line-height:1.1; }
.cv-id .rl{ color:var(--orange-ink); font-weight:600; font-size:clamp(16px,1.6vw,20px); margin-top:10px; letter-spacing:-0.01em; }
.cv-id .meta{ margin-top:26px; display:flex; flex-direction:column; gap:0; }
.cv-id .meta .row{ display:grid; grid-template-columns:120px 1fr; gap:16px; padding:14px 0; border-top:1px solid var(--line); }
.cv-id .meta .row:last-child{ border-bottom:1px solid var(--line); }
.cv-id .meta dt{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.cv-id .meta dd{ font-size:clamp(15px,1.5vw,18px); color:var(--ink); }
@media (max-width:760px){ .cv-head{ grid-template-columns:1fr; } .cv-portrait{ max-width:340px; } }

.cv-block{ display:grid; grid-template-columns:200px 1fr; gap:clamp(20px,4vw,56px); padding-block:clamp(36px,4.5vw,58px); border-top:1px solid var(--line); }
.cv-block h3{ font-family:var(--mono); font-size:13px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--orange-ink); padding-top:6px; }
.cv-list{ display:flex; flex-direction:column; }
.cv-row{ display:grid; grid-template-columns:auto 70px 1fr; gap:16px; align-items:baseline; padding:13px 0; border-bottom:1px solid var(--line-2); }
.cv-row:first-child{ border-top:1px solid var(--line-2); }
.cv-row .pf{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--ink-3); border:1px solid var(--line); border-radius:999px; padding:3px 9px; justify-self:start; min-width:38px; text-align:center; }
.cv-row .pf.now{ color:#fff; background:var(--orange); border-color:var(--orange); }
.cv-row .yr{ font-family:var(--mono); font-size:13px; color:var(--orange-ink); }
.cv-row .tx{ font-size:clamp(15px,1.45vw,17.5px); color:var(--ink); line-height:1.5; letter-spacing:-0.01em; text-wrap:pretty; }
.cv-row .tx .sub{ color:var(--ink-3); }
.cv-list.simple .cv-row{ grid-template-columns:1fr; }
.cv-list.noprefix .cv-row{ grid-template-columns:70px 1fr; }
@media (max-width:560px){ .cv-block{ grid-template-columns:1fr; gap:14px; } .cv-row{ grid-template-columns:auto 1fr; } .cv-row .yr{ grid-column:1; } .cv-list.noprefix .cv-row{ grid-template-columns:70px 1fr; } }

/* CV expandable toggle (overview chairman section) */
.cv-toggle{
  margin-top:24px; display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); background:transparent; border:1px solid var(--line); border-radius:999px;
  padding:11px 20px; transition:background .25s, border-color .25s, color .25s;
}
.cv-toggle:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.cv-toggle .cv-chev{ width:15px; height:15px; transition:transform .3s ease; }
.cv-toggle.is-open .cv-chev{ transform:rotate(180deg); }
.cv-panel{ max-height:0; overflow:hidden; transition:max-height .45s ease; margin-top:8px; }
.cv-panel .cv-block:first-child{ border-top:none; }

/* Vision 2030 → social-contribution CTA */
.v30-foot{ margin-top:clamp(36px,5vw,64px); padding-top:clamp(28px,3.5vw,40px); border-top:1px solid rgba(246,244,239,.16);
  display:flex; flex-wrap:wrap; align-items:center; justify-content:flex-start; gap:24px; }
.v30-foot-tx{ color:rgba(246,244,239,.78); font-size:clamp(16px,1.5vw,19px); line-height:1.6; max-width:48ch; text-wrap:pretty; }
.btn.light{ background:var(--paper); color:var(--ink); border:none; }
.btn.light:hover{ background:var(--orange); color:#fff; }

/* ---------- DRAWER sub-items ---------- */
.drawer-sub{ display:flex; flex-direction:column; gap:12px; padding:4px 0 8px 18px; margin-top:-2px; border-left:2px solid rgba(246,244,239,.2); }
.drawer-sub a{ font-size:18px; font-weight:500; color:rgba(246,244,239,.74); }
.drawer-sub a .en{ display:none; }