/*
Theme Name: AXIS Theme
Theme URI: https://axistrade.jp
Author: KATO_AXIS
Author URI: https://axistrade.jp
Description: Dark premium theme for KATO_AXIS — FX Trader / Developer. No build tools. Vanilla CSS/JS only. Customizer image management (9 keys). All page content embedded in templates.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: axis-theme
*/

/* ═══════════════════════════════════════
   VARIABLES
   ═══════════════════════════════════════ */
:root{
  --bg:#111111;
  --block:#1C1C1C;
  --block2:#161616;
  --block3:#222222;
  --text:#E5E5E5;
  --sub:rgba(229,229,229,.78);
  --dim:rgba(229,229,229,.45);
  --border:#333;
  --border-h:#555;
  --gold:#c9a44e;
  --gold2:#dbb96a;
  --gold3:#a8852e;
  --max:1100px;
  --r:18px;
  --r-lg:22px;
  --r-sm:12px;
  --font:system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
}

/* ═══════════════════════════════════════
   RESET
   ═══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:72px}
body{font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{font-family:inherit}

/* ═══════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════ */
.ax-w{max-width:var(--max);margin:0 auto;padding:0 24px}
.ax-sec{padding:80px 0}
.ax-sec-alt{background:var(--block2)}

/* ═══════════════════════════════════════
   HEADER — sticky
   ═══════════════════════════════════════ */
.ax-topbar{position:sticky;top:0;z-index:200;
  background:rgba(17,17,17,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.05)}
.ax-topbar-in{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
.ax-logo{font-size:14px;font-weight:900;letter-spacing:1.8px;color:#fff;white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px}
.ax-logo img{height:28px;width:auto}
/* wp_nav_menu container */
.ax-nav{display:flex;align-items:center}
.ax-nav ul{display:flex;gap:22px;font-size:12px;font-weight:700;letter-spacing:.5px;list-style:none;margin:0;padding:0}
.ax-nav li a{color:var(--sub);padding:6px 0;transition:color .2s;display:block}
.ax-nav li a:hover,
.ax-nav li.current-menu-item a,
.ax-nav li.current_page_item a{color:#fff}

/* ── Hamburger ── */
.ax-hb{display:none;background:none;border:none;cursor:pointer;padding:6px;z-index:210;flex-shrink:0}
.ax-hb span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;margin:5px 0;transition:.25s}
.ax-hb[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.ax-hb[aria-expanded="true"] span:nth-child(2){opacity:0}
.ax-hb[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── Mobile Nav ── */
.ax-mobile-nav{display:none;position:fixed;inset:0;z-index:199;
  background:rgba(17,17,17,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  flex-direction:column;align-items:center;justify-content:center;gap:20px}
.ax-mobile-nav[aria-hidden="false"]{display:flex}
.ax-mobile-nav a{color:#fff;font-size:17px;font-weight:800;padding:8px 0;transition:color .2s}
.ax-mobile-nav a:hover{color:var(--gold)}

/* ═══════════════════════════════════════
   BUTTONS — thin gray border, no fill
   ═══════════════════════════════════════ */
.ax-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 30px;border-radius:var(--r);
  border:1.5px solid var(--border);background:transparent;color:var(--text);
  font-size:13px;font-weight:800;letter-spacing:.5px;cursor:pointer;
  transition:all .2s;white-space:nowrap}
.ax-btn:hover{border-color:var(--border-h);background:rgba(255,255,255,.05);color:#fff}
.ax-btn-primary{border-width:2px;border-color:var(--border-h)}
.ax-btn-primary:hover{border-color:#888}
.ax-btn-row{display:flex;flex-wrap:wrap;gap:14px}
.ax-btn-sm{padding:11px 20px;font-size:12px}

/* ═══════════════════════════════════════
   TYPOGRAPHY
   ═══════════════════════════════════════ */
.ax-h1{font-size:clamp(28px,4.2vw,50px);font-weight:900;line-height:1.12;letter-spacing:.5px;color:#fff}
.ax-h2{font-size:clamp(22px,3vw,34px);font-weight:900;line-height:1.18;color:#fff;margin-bottom:20px}
.ax-h3{font-size:18px;font-weight:800;color:#fff;margin-bottom:10px}
.ax-h4{font-size:15px;font-weight:800;color:#fff;margin-bottom:8px}
.ax-label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:2px;
  color:var(--dim);text-transform:uppercase;margin-bottom:14px}
.ax-lead{color:var(--sub);font-size:15px;font-weight:600;line-height:1.9;max-width:560px}
.ax-body{color:var(--sub);font-size:14px;font-weight:600;line-height:1.85}
.ax-small{font-size:11px;color:var(--dim);line-height:1.7}

/* ═══════════════════════════════════════
   CARDS
   ═══════════════════════════════════════ */
.ax-card{background:var(--block);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:32px}
.ax-card-sm{padding:24px}

/* ═══════════════════════════════════════
   GRIDS
   ═══════════════════════════════════════ */
.ax-g2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.ax-g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* ═══════════════════════════════════════
   HERO — full viewport
   ═══════════════════════════════════════ */
.ax-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;position:relative;overflow:hidden}
.ax-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;pointer-events:none}
.ax-hero-bg.has-img{opacity:.18}
.ax-hero-bg.no-img{
  background:
    radial-gradient(ellipse 700px 450px at 50% 38%,rgba(255,255,255,.035),transparent),
    radial-gradient(ellipse 240px 240px at 28% 16%,rgba(201,164,78,.025),transparent),
    radial-gradient(ellipse 240px 240px at 72% 62%,rgba(201,164,78,.015),transparent)}
/* noise overlay */
.ax-hero::after{content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  opacity:.5;pointer-events:none}
.ax-hero-content{position:relative;z-index:1}
.ax-hero .ax-name{font-size:13px;font-weight:800;letter-spacing:2.5px;color:var(--sub);margin-bottom:4px}
.ax-hero .ax-role{font-size:12px;color:var(--dim);font-weight:700;letter-spacing:1.2px;margin-bottom:28px}
.ax-hero .ax-h1{margin-bottom:20px}
.ax-hero .ax-lead{margin:0 auto 44px;text-align:center}
.ax-hero .ax-btn-row{justify-content:center}

/* ═══════════════════════════════════════
   PHILOSOPHY 2-COL
   ═══════════════════════════════════════ */
.ax-philo{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.ax-philo-text .ax-body{white-space:pre-line}
.ax-philo-visual{border-radius:var(--r);min-height:360px;position:relative;overflow:hidden;
  background:var(--block);border:1px solid rgba(255,255,255,.06)}
.ax-philo-visual.has-img{background-size:cover;background-position:center}
.ax-philo-visual.no-img::before{content:"";position:absolute;inset:20px;border:1px solid rgba(255,255,255,.04);border-radius:8px;
  background:repeating-linear-gradient(0deg,transparent,transparent 30px,rgba(255,255,255,.02) 30px,rgba(255,255,255,.02) 31px),
    repeating-linear-gradient(90deg,transparent,transparent 50px,rgba(255,255,255,.02) 50px,rgba(255,255,255,.02) 51px)}
.ax-philo-visual.no-img::after{content:"CHART";position:absolute;bottom:28px;right:28px;
  font-size:11px;font-weight:800;letter-spacing:2px;color:rgba(255,255,255,.07)}

/* ═══════════════════════════════════════
   PROFILE
   ═══════════════════════════════════════ */
.ax-profile-foot{text-align:center;margin-top:44px;font-size:16px;font-weight:800;color:var(--sub);line-height:1.7}

/* ═══════════════════════════════════════
   SERVICE CARDS
   ═══════════════════════════════════════ */
.ax-svc-card{display:flex;flex-direction:column;min-height:320px;overflow:hidden}
.ax-svc-thumb{height:160px;background:var(--block2);background-size:cover;background-position:center;
  border-radius:var(--r) var(--r) 0 0;position:relative}
.ax-svc-thumb.no-img{background:linear-gradient(135deg,var(--block),var(--block2))}
.ax-svc-thumb .ax-svc-tag{position:absolute;top:14px;left:14px;
  font-size:10px;font-weight:900;letter-spacing:1.5px;color:var(--dim);text-transform:uppercase}
.ax-svc-body{padding:24px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.ax-svc-body .ax-body{margin-bottom:18px}

/* ═══════════════════════════════════════
   SLIDER (horizontal, CSS scroll-snap)
   ═══════════════════════════════════════ */
.ax-slider{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;padding-bottom:8px}
.ax-slider::-webkit-scrollbar{height:4px}
.ax-slider::-webkit-scrollbar-track{background:var(--block);border-radius:4px}
.ax-slider::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.ax-slide{flex:0 0 320px;scroll-snap-align:start;border-radius:var(--r);overflow:hidden;
  background:var(--block);border:1px solid rgba(255,255,255,.06)}
.ax-slide-img{height:210px;background:var(--block2);background-size:cover;background-position:center;
  display:grid;place-items:center;color:var(--dim);font-size:12px;font-weight:700;letter-spacing:1px}
.ax-slide-img.has-img{color:transparent}
.ax-slide-body{padding:18px}
.ax-slide-body p{font-size:13px;color:var(--sub);font-weight:700}
.ax-slider-note{margin-top:20px;font-size:11px;color:var(--dim);font-weight:700;text-align:center}

/* ═══════════════════════════════════════
   CTA BAND
   ═══════════════════════════════════════ */
.ax-cta-band{padding:80px 0;text-align:center;
  border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.ax-cta-band .ax-h2{margin-bottom:36px}

/* ═══════════════════════════════════════
   PAGE HEADER (sub-pages)
   ═══════════════════════════════════════ */
.ax-page-header{padding:120px 0 56px;text-align:center;border-bottom:1px solid rgba(255,255,255,.04)}

/* ═══════════════════════════════════════
   FIT LIST
   ═══════════════════════════════════════ */
.ax-fit-list li{padding:9px 0;font-size:14px;font-weight:700;color:var(--sub);
  border-bottom:1px solid rgba(255,255,255,.04)}
.ax-fit-list li::before{content:"\2192\00a0";color:var(--dim)}

/* ═══════════════════════════════════════
   MODEL DIAGRAM
   ═══════════════════════════════════════ */
.ax-diagram{border-radius:var(--r);min-height:280px;background:var(--block);
  border:1px solid rgba(255,255,255,.06);overflow:hidden;position:relative}
.ax-diagram.has-img{background-size:contain;background-position:center;background-repeat:no-repeat}
.ax-diagram.no-img{display:flex;align-items:center;justify-content:center}
.ax-diagram.no-img::after{content:"\96C6\5BA2 \2192 \914D\4FE1 \2192 \8CA9\58F2 \2192 \904B\7528 \2192 \518D\73FE";
  font-size:13px;font-weight:800;letter-spacing:1px;color:var(--dim);padding:24px}

/* ═══════════════════════════════════════
   FAQ
   ═══════════════════════════════════════ */
.ax-faq{max-width:700px;margin:0 auto}
.ax-faq details{border-bottom:1px solid rgba(255,255,255,.06)}
.ax-faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;
  justify-content:space-between;gap:16px;padding:22px 0;font-weight:800;font-size:15px;color:#fff}
.ax-faq summary::-webkit-details-marker{display:none}
.ax-faq .faq-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  border:1px solid var(--border);font-size:15px;font-weight:900;flex-shrink:0;
  color:var(--sub);transition:transform .25s}
.ax-faq details[open] .faq-ic{transform:rotate(45deg)}
.ax-faq .faq-a{padding:0 0 24px;color:var(--sub);font-size:14px;font-weight:600;line-height:1.8}
.ax-faq .faq-note{font-size:11px;color:var(--dim);margin-top:8px}

/* ═══════════════════════════════════════
   FORM
   ═══════════════════════════════════════ */
.ax-form{max-width:600px;margin:0 auto}
.ax-form label{display:block;margin-bottom:6px;font-size:12px;font-weight:800;letter-spacing:.5px;color:var(--sub)}
.ax-form .req{color:#fc8181}
.ax-form input,.ax-form select,.ax-form textarea{
  width:100%;padding:14px 16px;background:var(--block);border:1px solid var(--border);
  border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:14px;font-weight:600;transition:border-color .2s}
.ax-form input:focus,.ax-form select:focus,.ax-form textarea:focus{outline:none;border-color:var(--border-h)}
.ax-form select{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.ax-form textarea{min-height:140px;resize:vertical}
.ax-form .ax-field{margin-bottom:22px}
.ax-form .ax-hp{position:absolute;left:-9999px}
.ax-form-msg{padding:16px 20px;border-radius:var(--r-sm);margin-bottom:24px;font-size:14px;font-weight:700}
.ax-form-msg.ok{background:rgba(72,187,120,.08);border:1px solid rgba(72,187,120,.18);color:#68d391}
.ax-form-msg.err{background:rgba(245,101,101,.08);border:1px solid rgba(245,101,101,.18);color:#fc8181}

/* ═══════════════════════════════════════
   LEGAL PAGES
   ═══════════════════════════════════════ */
.ax-legal{max-width:700px;margin:0 auto}
.ax-legal h3{font-size:16px;font-weight:800;color:#fff;margin:36px 0 10px}
.ax-legal h3:first-child{margin-top:0}
.ax-legal p{color:var(--sub);font-size:14px;font-weight:600;line-height:1.85;margin-bottom:14px}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.ax-footer{padding:48px 0;border-top:1px solid rgba(255,255,255,.06);text-align:center;
  font-size:12px;color:var(--dim);font-weight:700}
.ax-footer-links{margin-bottom:14px;display:flex;flex-wrap:wrap;justify-content:center;gap:18px}
.ax-footer-links a{color:var(--sub);transition:color .2s}
.ax-footer-links a:hover{color:#fff}
.ax-footer-disc{max-width:620px;margin:14px auto 0;font-size:11px;line-height:1.8;color:var(--dim)}

/* ═══════════════════════════════════════
   FADE-IN
   ═══════════════════════════════════════ */
.fi{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.fi.vis{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:900px){
  .ax-nav{display:none!important}
  .ax-hb{display:block}
  .ax-g3{grid-template-columns:1fr}
  .ax-g2{grid-template-columns:1fr}
  .ax-philo{grid-template-columns:1fr;gap:28px}
  .ax-philo-visual{min-height:240px}
  .ax-hero{min-height:88vh}
  .ax-sec{padding:56px 0}
  .ax-cta-band{padding:56px 0}
  .ax-page-header{padding:96px 0 44px}
}
@media(max-width:600px){
  .ax-h1{font-size:26px}
  .ax-card{padding:20px}
  .ax-slide{flex:0 0 270px}
  .ax-svc-thumb{height:130px}
}
