/*
Theme Name: OH JAE WON — SOLO/BUILDER
Theme URI: https://ohjaewon.com
Description: GeneratePress 자식 테마. SOLO/BUILDER 전략 나침반 디자인 — 그리드 배경 + 모노스페이스 + 동적 프레임워크 색인.
Author: ohdaepyo
Template: generatepress
Version: 1.0.4
Text Domain: ohjaewon-solobuilder
*/

/* =========================================================
   0. Design tokens
   ========================================================= */
:root{
  --bg:#F5F6F8; --panel:#FFFFFF;
  --ink:#0E1318; --ink2:#3A434D; --mute:#5B6670;
  --line:#D9DEE4; --line2:#E8ECF0;
  --blue:#1F5FE0; --teal:#0B8C81; --steel:#46525E;
  --grid:rgba(20,40,70,.05);
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --display:'Archivo','Archivo Fallback',-apple-system,BlinkMacSystemFont,sans-serif;
  --kr:'IBM Plex Sans KR','IBM Plex KR Fallback',-apple-system,BlinkMacSystemFont,'Malgun Gothic','Apple SD Gothic Neo',sans-serif;
}

/* =========================================================
   Metric-matched fallback fonts — kill FOUT reflow (CLS)
   while keeping web fonts (display=swap). Fallback occupies
   the same line/advance space as the real font until it loads.
   Hangul are full-width → size-adjust:100% keeps line wrapping.
   ========================================================= */
@font-face{
  font-family:'IBM Plex KR Fallback';
  src:local('Malgun Gothic'),local('AppleSDGothicNeo-Regular'),local('Apple SD Gothic Neo'),local('Noto Sans KR'),local('Noto Sans CJK KR'),local('Nanum Gothic');
  font-weight:400 600;font-style:normal;
  ascent-override:102.5%;descent-override:27.5%;line-gap-override:0%;size-adjust:100%;
}
@font-face{
  font-family:'IBM Plex KR Fallback';
  src:local('Malgun Gothic Bold'),local('AppleSDGothicNeo-Bold'),local('Noto Sans KR'),local('Nanum Gothic Bold');
  font-weight:700;font-style:normal;
  ascent-override:102.5%;descent-override:27.5%;line-gap-override:0%;size-adjust:100%;
}
/* Self-hosted Archivo (variable, Latin) — display font, preloaded for
   first-paint fidelity. Korean/mono stay on Google with display=optional. */
@font-face{
  font-family:'Archivo';
  src:url('fonts/archivo-latin.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Archivo Fallback';
  src:local('Arial'),local('Helvetica Neue'),local('Segoe UI'),local('Roboto');
  font-weight:500 900;font-style:normal;
  ascent-override:100%;descent-override:27.8%;line-gap-override:0%;size-adjust:100%;
}

/* =========================================================
   1. Global base + grid background (sitewide)
   ========================================================= */
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--kr);-webkit-font-smoothing:antialiased;
  line-height:1.62;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:30px 30px;
}
a{color:inherit;text-decoration:none}
.ohjw-wrap{max-width:1080px;margin:0 auto;padding:0 30px}

/* keep GP content above the grid bg */
.site-header,#page,.site-content,.ohjw-bar,#ohjw-mast,.ohjw-foot,.ohjw-home{position:relative;z-index:1}

/* focus visibility */
.ohjw-nav a:focus-visible,.ohjw-btn:focus-visible,.fcard:focus-visible,
.ohjw-home a:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* =========================================================
   2. Hide GeneratePress default chrome we replace
   ========================================================= */
.site-header#masthead,
#mobile-header,
.generate-top-bar,
.top-bar,
#generate-slideout-menu,
.slideout-overlay,
.main-navigation:not(.ohjw-nav-wrap){display:none !important}

/* =========================================================
   3. Top status bar
   ========================================================= */
.ohjw-bar{border-bottom:1px solid var(--line);background:transparent}
.ohjw-bar .ohjw-wrap{display:flex;justify-content:space-between;align-items:center;height:40px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--mute);text-transform:uppercase}
.ohjw-bar .live{display:inline-flex;align-items:center;gap:8px;color:var(--teal);font-weight:600}
.ohjw-bar .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);animation:ohjwPulse 1.8s infinite}
@keyframes ohjwPulse{0%,100%{opacity:1}50%{opacity:.3}}

/* =========================================================
   4. Masthead
   ========================================================= */
#ohjw-mast{background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
#ohjw-mast .ohjw-wrap{display:flex;align-items:center;justify-content:space-between;height:68px;gap:20px}
.ohjw-brand{display:flex;align-items:center;gap:13px}
.ohjw-brand .bt{font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:.02em;color:var(--ink)}
.ohjw-brand .bt .sl{color:var(--blue)}
.ohjw-brand .bsub{font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:var(--steel);
  text-transform:uppercase;font-weight:600;display:block;margin-top:1px}

.ohjw-nav{display:flex;gap:4px;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;font-weight:500;
  list-style:none;margin:0;padding:0;align-items:center}
.ohjw-nav li{margin:0;padding:0}
.ohjw-nav a{display:block;padding:8px 13px;border-radius:7px;color:var(--ink2);transition:background .2s,color .2s}
.ohjw-nav a:hover{background:#EEF2F7;color:var(--ink)}
.ohjw-nav .current-menu-item>a,.ohjw-nav a.on{color:var(--blue);font-weight:700}

@keyframes ohjwCoreBreathe{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}
.gemmark .halo{transform-origin:100px 100px;animation:ohjwCoreBreathe 4.2s ease-in-out infinite}
@keyframes ohjwMtwinkle{0%,100%{opacity:.55}50%{opacity:1}}
.gemmark .mnode{animation:ohjwMtwinkle 3.6s ease-in-out infinite}

.ohjw-mark{display:block;flex:none;width:36px;height:36px}

.ohjw-btn{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.08em;
  border:1.5px solid var(--blue);color:var(--blue);border-radius:8px;padding:8px 15px;
  background:var(--panel);cursor:pointer;transition:background .2s,color .2s;display:inline-block}
.ohjw-btn:hover{background:var(--blue);color:#fff}

/* mobile nav toggle */
.ohjw-navtoggle{display:none;background:none;border:1.5px solid var(--line);border-radius:8px;
  width:38px;height:38px;cursor:pointer;align-items:center;justify-content:center;color:var(--ink2)}
.ohjw-navtoggle svg{width:18px;height:18px}

/* =========================================================
   5. Homepage — full width override
   ========================================================= */
.home #page,.home .site-content,.home #content,.home #primary,
.home .content-area,.home #main,
.archive #page,.archive .site-content,.archive #content,.archive #primary,.archive .content-area,.archive #main,
.blog #page,.blog .site-content,.blog #content,.blog #primary,.blog .content-area,.blog #main,
.search #page,.search .site-content,.search #content,.search #primary,.search .content-area,.search #main{
  max-width:100% !important;width:100% !important;padding:0 !important;margin:0 !important;
}
.home #content,.archive #content,.blog #content,.search #content{display:block}
.ohjw-home{padding-bottom:10px}

/* let the fixed grid (body::before) show through — graph-paper look from mockup.
   GP fills .container/.inside-article with an opaque bg; make wrappers transparent
   on card layouts (panels/cards keep their own white bg). */
.home #page,.home .site-content,.home #content,.home #primary,.home .content-area,.home #main,
.home .one-container .container,.home .separate-containers .container,.home .inside-article,
.archive #page,.archive .site-content,.archive #content,.archive #primary,.archive .content-area,.archive #main,
.archive .one-container .container,.archive .separate-containers .container,.archive .inside-article,
.blog #page,.blog .site-content,.blog #content,.blog .one-container .container,.blog .inside-article,
.search #page,.search .site-content,.search #content,.search .one-container .container,.search .inside-article,
.ohjw-home,.ohjw-home .block{background:transparent !important}

/* section base */
.ohjw-home .block{padding:46px 0}
.ohjw-home .block.line{border-top:1px solid var(--line)}
.ohjw-home .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--blue);
  text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:10px;margin-bottom:18px}
.ohjw-home .eyebrow .num{color:var(--mute)}
.ohjw-home .eyebrow .rule{flex:1;height:1px;background:var(--line)}

/* featured / latest */
.ohjw-home .feat{border:1px solid var(--line);border-radius:14px;background:var(--panel);overflow:hidden;
  display:grid;grid-template-columns:1.4fr 1fr}
.ohjw-home .feat .body{padding:32px 36px 30px}
.ohjw-home .feat .stamp{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);
  border:1px solid currentColor;border-radius:6px;padding:4px 10px}
.ohjw-home .feat h2{font-family:var(--kr);font-weight:700;font-size:clamp(21px,3.2vw,28px);
  letter-spacing:-.02em;line-height:1.3;margin:15px 0 11px}
.ohjw-home .feat h2 .en{font-family:var(--display);color:var(--steel);font-weight:600;font-size:.62em;
  display:block;margin-top:4px;letter-spacing:0}
.ohjw-home .feat h2 a:hover{color:var(--blue)}
.ohjw-home .feat .ex{font-size:14.5px;color:var(--ink2);max-width:520px}
.ohjw-home .feat .meta{display:flex;gap:18px;margin-top:20px;font-family:var(--mono);
  font-size:11px;color:var(--steel);letter-spacing:.05em;flex-wrap:wrap}
.ohjw-home .feat .meta b{color:var(--blue);font-weight:700}
.ohjw-home .feat .fig{background:#EEF1F4;border-left:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;padding:26px;min-height:200px}
.ohjw-home .feat .fig img{width:100%;height:100%;max-height:240px;object-fit:cover;border-radius:6px}

/* framework cards */
.ohjw-home .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ohjw-home .fcard{display:block;background:var(--panel);border:1px solid var(--line);border-radius:13px;
  overflow:hidden;transition:border-color .25s,transform .25s,box-shadow .25s}
.ohjw-home .fcard:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 12px 30px rgba(31,95,224,.1)}
.ohjw-home .fcard .thumb{height:128px;background:#F2F5F8;border-bottom:1px solid var(--line2);
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.ohjw-home .fcard .thumb::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:16px 16px}
.ohjw-home .fcard .thumb svg,.ohjw-home .fcard .thumb img{position:relative}
.ohjw-home .fcard .thumb img{width:100%;height:100%;object-fit:cover}
.ohjw-home .fcard .pad{padding:19px 22px 20px}
.ohjw-home .fcard .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.ohjw-home .fcard .idx{font-family:var(--mono);font-size:10px;letter-spacing:.1em;font-weight:700;color:var(--blue)}
.ohjw-home .fcard .cat{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;font-weight:600;
  text-transform:uppercase;color:var(--steel);border:1px solid var(--line);border-radius:5px;
  padding:3px 8px;background:#F7F9FB}
.ohjw-home .fcard h3{font-family:var(--kr);font-weight:700;font-size:16px;letter-spacing:-.01em;line-height:1.4;margin-bottom:7px;color:var(--ink)}
.ohjw-home .fcard p{font-size:13px;color:var(--ink2);line-height:1.56;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ohjw-home .fcard .foot2{display:flex;justify-content:space-between;margin-top:14px;
  font-family:var(--mono);font-size:10.5px;color:var(--mute);letter-spacing:.05em}
.ohjw-home .more{margin-top:26px;text-align:center}
.ohjw-home .more .ohjw-btn{padding:11px 26px;font-size:11.5px}

/* series index */
.ohjw-home .axes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ohjw-home .ax{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:24px;
  transition:border-color .25s,transform .25s;display:block}
.ohjw-home .ax:hover{border-color:var(--blue);transform:translateY(-2px)}
.ohjw-home .ax .k{font-family:var(--mono);font-size:10px;color:var(--blue);letter-spacing:.1em;font-weight:700}
.ohjw-home .ax h3{font-family:var(--kr);font-weight:700;font-size:17px;margin:10px 0 7px;color:var(--ink)}
.ohjw-home .ax p{font-size:13px;color:var(--ink2);line-height:1.55}
.ohjw-home .ax .cnt{font-family:var(--mono);font-size:10.5px;color:var(--steel);margin-top:14px;
  font-weight:600;letter-spacing:.06em}
.ohjw-home .ax .cnt b{color:var(--teal)}

/* subscribe */
.ohjw-home .sub{background:var(--ink);border-radius:14px;padding:36px 40px;color:#fff;
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  position:relative;overflow:hidden}
.ohjw-home .sub::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:30px 30px}
.ohjw-home .sub .tx{position:relative}
.ohjw-home .sub .k{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:#36d6c8;
  text-transform:uppercase;font-weight:700}
.ohjw-home .sub h3{font-family:var(--kr);font-weight:700;font-size:21px;letter-spacing:-.02em;margin:9px 0 6px;color:#fff}
.ohjw-home .sub p{font-size:13.5px;color:#aeb8c2;max-width:440px}
.ohjw-home .sub .form{position:relative}
.ohjw-home .sub .form .wp-block-jetpack-subscriptions__container,
.ohjw-home .sub .form form{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.ohjw-home .sub input[type=email]{font-family:var(--mono);font-size:12px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.22);border-radius:8px;color:#fff;padding:11px 15px;min-width:230px}
.ohjw-home .sub input[type=email]::placeholder{color:#7e8a96}
.ohjw-home .sub button,.ohjw-home .sub .go{font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:.08em;
  background:var(--blue) !important;border:none;color:#fff !important;border-radius:8px;padding:11px 20px;cursor:pointer;
  transition:background .2s}
.ohjw-home .sub button:hover,.ohjw-home .sub .go:hover{background:#1a4fc0 !important}

/* =========================================================
   6. Footer
   ========================================================= */
.ohjw-foot{border-top:1px solid var(--line);background:var(--panel);padding:24px 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--steel)}
.ohjw-foot .ohjw-wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;text-transform:uppercase}
.ohjw-foot b{color:var(--teal);font-weight:700}
.ohjw-foot a:hover{color:var(--blue)}

/* =========================================================
   7. Article / archive restyle (SOLO/BUILDER palette)
   ========================================================= */
.site-content{padding-top:0}
.single .entry-header,.page .entry-header,.archive .page-header{margin-bottom:8px}
.single .entry-title,.page .entry-title,.archive .page-title,
.single h1,.page h1{font-family:var(--kr);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.entry-content{font-family:var(--kr);font-size:16px;color:var(--ink2)}
.entry-content h2,.entry-content h3,.entry-content h4{font-family:var(--kr);font-weight:700;color:var(--ink);letter-spacing:-.01em}
.entry-content a{color:var(--blue)}
.entry-content a:hover{text-decoration:underline}
.entry-content code,.entry-content pre{font-family:var(--mono)}
.entry-content blockquote{border-left:3px solid var(--blue);background:var(--panel);
  padding:14px 20px;border-radius:0 8px 8px 0;color:var(--ink2)}
.entry-content table{border:1px solid var(--line)}
.entry-content table th{background:#F2F5F8;font-family:var(--mono);font-size:13px}
.entry-meta,.posted-on,.byline,.cat-links{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--steel)}
.entry-meta a{color:var(--steel)}
.entry-meta a:hover{color:var(--blue)}

/* injected single-post coords strip */
.ohjw-coords{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--steel);
  display:flex;gap:18px;flex-wrap:wrap;margin:6px 0 18px;text-transform:uppercase}
.ohjw-coords b{color:var(--blue);font-weight:700}

/* archive card grid */
.ohjw-arc-head{padding:40px 0 6px}
.ohjw-arc-head .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--blue);
  text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ohjw-arc-head .eyebrow .rule{flex:1;height:1px;background:var(--line)}
.ohjw-arc-head h1{font-family:var(--display);font-weight:800;font-size:clamp(26px,4vw,40px);letter-spacing:-.02em;color:var(--ink)}
.ohjw-arc-head .desc{margin-top:10px;color:var(--ink2);font-size:14.5px;max-width:640px}
.ohjw-arcgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px 0 50px}

/* pagination */
.ohjw-pager,.archive .paging-navigation,.blog .paging-navigation{font-family:var(--mono);font-size:12px;
  letter-spacing:.06em;margin:10px 0 50px}
.archive .paging-navigation a,.blog .paging-navigation a{border:1px solid var(--line);border-radius:7px;
  padding:8px 14px;color:var(--ink2);background:var(--panel)}
.archive .paging-navigation a:hover,.blog .paging-navigation a:hover{border-color:var(--blue);color:var(--blue)}

/* =========================================================
   8. Responsive
   ========================================================= */
@media(max-width:880px){
  .ohjw-home .feat{grid-template-columns:1fr}
  .ohjw-home .feat .fig{border-left:none;border-top:1px solid var(--line)}
  .ohjw-home .grid,.ohjw-home .axes,.ohjw-arcgrid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:620px){
  .ohjw-nav{position:absolute;top:68px;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--panel);border-bottom:1px solid var(--line);padding:8px 30px 14px;gap:2px;display:none;
    box-shadow:0 10px 24px rgba(14,19,24,.08)}
  .ohjw-nav.open{display:flex}
  .ohjw-navtoggle{display:inline-flex}
  .ohjw-home .grid,.ohjw-home .axes,.ohjw-arcgrid{grid-template-columns:1fr}
  .ohjw-home .sub{padding:30px 26px}
  .ohjw-wrap{padding:0 20px}
}
@media (prefers-reduced-motion: reduce){
  .ohjw-bar .live::before,.gemmark .halo,.gemmark .mnode,.compass .needle{animation:none}
}
