/*
Theme Name: HIX Corporation
Theme URI: https://www.hixcorp.com/
Author: Clever Fox Creative
Author URI: https://gocleverfox.com/
Description: A customizable brand-portal theme for HIX Corporation. A dark, thermal-instrument landing page that routes visitors to the company's brands — each presented as a "heat channel" that energizes on interaction. Hero, About band, three brand cards, and the contact block are all editable from Appearance → Customize.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hix-corporation
*/

/* ============================================================
   HIX CORPORATION — brand portal
   Concept: HIX is a heat company. Each brand is a "thermal
   channel" that energizes on interaction (cold steel -> glowing
   brand color). One source, three brands.
   Per-brand color is injected inline on each .brand from the
   Customizer; :root values below are defaults / fallbacks.
   ============================================================ */

:root{
  --bg:        #0C0D10;
  --panel:     #131419;
  --panel-2:   #16181F;
  --line:      #25282F;
  --steel:     #3C414C;
  --text:      #ECECE6;
  --dim:       #9A9EA8;
  --faint:     #696D77;

  --hix:       #74A6FF;

  --qnc:  #FF8A2B;  --qnc-glow: #FFC178;
  --dxp:  #FF4537;  --dxp-glow: #FF8C82;
  --imp:  #2E84FF;  --imp-glow: #82B6FF;

  --maxw: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Archivo', system-ui, sans-serif;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:""; position:fixed; inset:0 0 auto 0; height:60vh; pointer-events:none; z-index:0;
  background:
    radial-gradient(120% 80% at 50% -20%, rgba(255,150,70,.10), transparent 60%),
    radial-gradient(90% 60% at 50% -10%, rgba(120,170,255,.06), transparent 55%);
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,48px); }

.mono{
  font-family:'IBM Plex Mono', ui-monospace, monospace;
  font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  font-size:.72rem; color:var(--faint);
}

.skip{ position:absolute; left:-999px; top:0; background:var(--text); color:var(--bg);
  padding:10px 16px; border-radius:4px; z-index:100; font-weight:600; }
.skip:focus{ left:16px; top:16px; }

:focus-visible{ outline:2px solid var(--hix); outline-offset:3px; border-radius:3px; }

/* ---------- top bar ---------- */
.site-header{ position:relative; z-index:2; }
.bar{ display:flex; align-items:center; justify-content:space-between; min-height:74px; border-bottom:1px solid var(--line); }
.brandmark{ display:flex; align-items:baseline; gap:11px; font-weight:900; letter-spacing:.02em; font-size:1.35rem; }
.brandmark img{ height:30px; width:auto; }
.brandmark .tag{ font-family:'IBM Plex Mono', monospace; font-weight:500; font-size:.62rem; letter-spacing:.22em; color:var(--faint); transform:translateY(-2px); }
.navlinks{ display:flex; align-items:center; gap:18px; }
.social-menu{ position:relative; }
.social-trigger{ display:inline-flex; align-items:center; gap:9px; cursor:pointer; font-family:'IBM Plex Mono', monospace; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text); background:none; border:1px solid var(--line); padding:10px 17px; border-radius:999px; transition:border-color .25s var(--ease), background .25s var(--ease); }
.social-trigger:hover{ border-color:var(--steel); background:rgba(255,255,255,.03); }
.social-trigger .chev{ width:11px; height:11px; transition:transform .3s var(--ease); }
.social-panel{ position:absolute; top:calc(100% + 12px); right:0; width:290px; z-index:30; background:var(--panel-2); border:1px solid var(--line); border-radius:14px; padding:6px; box-shadow:0 26px 64px -20px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.02) inset; opacity:0; visibility:hidden; transform:translateY(-8px) scale(.98); transform-origin:top right; transition:opacity .26s var(--ease), transform .26s var(--ease), visibility 0s linear .26s; }
.social-menu:hover .social-panel, .social-menu:focus-within .social-panel, .social-panel.open{ opacity:1; visibility:visible; transform:none; transition-delay:0s; }
.social-menu:hover .chev, .social-menu:focus-within .chev, .social-trigger[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.social-group{ padding:13px 13px 15px; }
.social-group + .social-group{ border-top:1px solid var(--line); }
.social-group .gl{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.social-group .gd{ width:6px; height:6px; border-radius:50%; background:var(--brand,var(--steel)); box-shadow:0 0 8px var(--brand,transparent); }
.social-group .gi{ width:24px; height:24px; border-radius:6px; object-fit:cover; display:block; flex:none; }
.social-group .gi.ph{ background:var(--brand,var(--steel)); box-shadow:0 0 12px -3px var(--brand,transparent); }
.social-group .gt{ font-family:'IBM Plex Mono', monospace; font-size:.62rem; letter-spacing:.13em; text-transform:uppercase; color:var(--dim); }
.social-row{ display:flex; gap:8px; }
.social-row a{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border:1px solid var(--line); border-radius:10px; color:var(--dim); transition:color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease), transform .25s var(--ease); }
.social-row a:hover{ color:var(--brand,var(--text)); border-color:var(--brand,var(--steel)); background:color-mix(in srgb, var(--brand,#fff) 13%, transparent); transform:translateY(-2px); }
.social-row a svg{ width:17px; height:17px; }

/* ---------- hero ---------- */
.hero{ position:relative; z-index:1; overflow:hidden; padding:clamp(60px,11vh,128px) 0 clamp(40px,7vh,72px); }
.hero-media{ position:absolute; inset:0; z-index:-1; pointer-events:none; }
.hero-media video, .hero-media img{ width:100%; height:100%; object-fit:cover; opacity:var(--hero-opacity,.3); }
.hero-media::after{ content:""; position:absolute; inset:0; opacity:var(--hero-overlay,1); background:linear-gradient(90deg, var(--bg) 0%, rgba(12,13,16,.62) 42%, rgba(12,13,16,.30) 100%), linear-gradient(0deg, var(--bg) 4%, rgba(12,13,16,.45) 40%, transparent 100%); }

/* ---------- hero FX: blueprint linework + ember drift ---------- */
.hero .wrap{ position:relative; z-index:1; }
.hero-fx{ position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.hero-fx .embers{ position:absolute; inset:0; width:100%; height:100%; opacity:var(--fx-embers,.7); }
.hero-fx .blueprint{ position:absolute; inset:0; width:100%; height:100%; color:#cdd9ea; opacity:var(--fx-blueprint,.16); animation:bpdrift 26s ease-in-out infinite alternate; }
.hero-fx .blueprint .ln{ fill:none; stroke:currentColor; stroke-width:1; vector-effect:non-scaling-stroke; }
.hero-fx .blueprint .draw{ stroke-dasharray:1; stroke-dashoffset:1; opacity:0; animation:bpdraw 17s linear infinite; }
@keyframes bpdraw{ 0%{ stroke-dashoffset:1; opacity:0; } 5%{ opacity:1; } 24%{ stroke-dashoffset:0; opacity:1; } 84%{ stroke-dashoffset:0; opacity:1; } 100%{ stroke-dashoffset:0; opacity:0; } }
@keyframes bpdrift{ from{ transform:translate(0,0) scale(1); } to{ transform:translate(-30px,16px) scale(1.012); } }

.hero .eyebrow{ margin:0 0 26px; }
.hero h1{ margin:0; font-weight:900; text-transform:uppercase; font-size:clamp(2.9rem,9vw,7rem); line-height:.9; letter-spacing:-.015em; }
.hero h1 .warm{ background:linear-gradient(95deg, var(--qnc), var(--dxp) 55%, var(--imp)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero p.lede{ max-width:46ch; margin:30px 0 0; color:var(--dim); font-size:clamp(1.02rem,1.6vw,1.22rem); line-height:1.5; }
.hero p.lede b{ color:var(--text); font-weight:600; }

.spectrum{ position:relative; height:2px; margin:clamp(46px,8vh,84px) 0 0; background:var(--line); overflow:hidden; }
.spectrum::before{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, var(--qnc), var(--dxp) 50%, var(--imp)); transform:scaleX(0); transform-origin:left center; animation:sweep 1.5s var(--ease) .25s forwards; }
.spectrum::after{ content:""; position:absolute; top:0; bottom:0; left:0; width:42%; background:linear-gradient(90deg, transparent, rgba(255,255,255,.7) 50%, transparent); mix-blend-mode:screen; transform:translateX(-170%); animation:spectrumpulse 5.5s ease-in-out 1.9s infinite; }
.spectrum .label{ position:absolute; top:10px; left:0; right:0; display:flex; justify-content:space-between; }
@keyframes sweep{ to{ transform:scaleX(1); } }
@keyframes spectrumpulse{ 0%{ transform:translateX(-170%); } 55%{ transform:translateX(400%); } 100%{ transform:translateX(400%); } }

/* ---------- about band ---------- */
.about{ position:relative; z-index:1; padding:clamp(52px,8vh,92px) 0 clamp(34px,5vh,56px); border-top:1px solid var(--line); }
.about .grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,76px); align-items:start; }
.about h2{ font-weight:800; text-transform:uppercase; line-height:1.02; letter-spacing:-.01em; font-size:clamp(1.7rem,3.4vw,2.7rem); margin:18px 0 0; max-width:15ch; }
.about h2 .warm{ background:linear-gradient(95deg, var(--qnc), var(--dxp) 55%, var(--imp)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.about p{ color:var(--dim); margin:24px 0 0; max-width:54ch; font-size:1.06rem; }
.about p b{ color:var(--text); font-weight:600; }
.stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:13px; overflow:hidden; margin-top:30px; }
.stat{ background:var(--panel); padding:24px 22px 22px; }
.stat .v{ font-weight:800; font-size:clamp(1.8rem,3vw,2.4rem); line-height:1; letter-spacing:-.01em; }
.stat .k{ margin-top:9px; color:var(--faint); display:block; }

/* ---------- brand channels ---------- */
.brandzone{ position:relative; z-index:1; }
.brands{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.6vw,22px); padding:clamp(24px,3.5vh,44px) 0 clamp(64px,9vh,104px); position:relative; z-index:1; }
.brand{ --brand:var(--steel); --brand-glow:var(--steel); position:relative; display:flex; flex-direction:column; min-height:min(74vh,620px); padding:30px 30px 32px; background:linear-gradient(180deg, var(--panel-2), var(--panel)); border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:border-color .5s var(--ease), transform .5s var(--ease); isolation:isolate; }
.brand::before{ content:""; position:absolute; inset:0; z-index:-2; opacity:.5; pointer-events:none; background:repeating-linear-gradient(180deg, rgba(255,255,255,.012) 0 1px, transparent 1px 4px); }
.brand-bg{ position:absolute; inset:0; z-index:-3; pointer-events:none; background-size:cover; background-position:center; opacity:var(--card-img,.5); transition:opacity .6s var(--ease), transform .6s var(--ease); transform:scale(1.02); }
.brand-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(12,13,16,.55) 0%, rgba(12,13,16,.80) 52%, rgba(12,13,16,.93) 100%); }
.bloom{ position:absolute; left:50%; top:34%; width:130%; height:60%; transform:translate(-50%,-50%); z-index:-1; pointer-events:none; opacity:0; background:radial-gradient(50% 50% at 50% 50%, var(--brand-glow), transparent 70%); transition:opacity .6s var(--ease); mix-blend-mode:screen; }

.channel-label{ display:flex; align-items:center; gap:11px; margin-bottom:auto; }
.channel-label .gi{ width:26px; height:26px; border-radius:6px; object-fit:cover; display:block; flex:none; opacity:.5; transition:opacity .5s var(--ease), filter .5s var(--ease); }
.channel-label .gi.ph{ background:var(--brand,var(--steel)); }
.channel-label .txt{ color:var(--dim); transition:color .5s var(--ease); }

.coil{ width:min(240px,70%); height:auto; margin:30px 0 26px; display:block; }
.coil .cold{ stroke:var(--steel); }
.coil .hot{ stroke:var(--brand); opacity:0; filter:drop-shadow(0 0 6px var(--brand-glow)); stroke-dasharray:100; stroke-dashoffset:100; transition:opacity .5s var(--ease), stroke-dashoffset .9s var(--ease); }

.brand .name{ font-weight:800; text-transform:uppercase; letter-spacing:.005em; font-size:clamp(1.5rem,2.6vw,2.05rem); line-height:1; margin:0 0 14px; }
.brand .name img{ height:clamp(26px,3.4vw,40px); width:auto; }
.brand .name sup{ font-size:.42em; font-weight:600; top:-.9em; }
.brand .desc{ color:var(--dim); font-size:1rem; line-height:1.5; margin:0 0 22px; max-width:34ch; }

.chips{ display:flex; flex-wrap:wrap; gap:8px; margin:0 0 26px; }
.chip{ font-family:'IBM Plex Mono', monospace; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--dim); border:1px solid var(--line); border-radius:999px; padding:6px 11px; transition:border-color .5s var(--ease), color .5s var(--ease); }

.enter{ display:inline-flex; align-items:center; gap:10px; align-self:flex-start; font-weight:700; font-size:1rem; letter-spacing:.01em; color:var(--text); padding:13px 22px; border-radius:999px; border:1px solid var(--steel); transition:border-color .45s var(--ease), background .45s var(--ease), gap .35s var(--ease); }
.enter .arr{ transition:transform .45s var(--ease); }

@media (hover:hover){
  .brand:hover{ border-color:color-mix(in srgb, var(--brand) 55%, var(--line)); transform:translateY(-4px); }
  .brand:hover .brand-bg{ opacity:var(--card-img-hover,.78); transform:scale(1.06); }
  .brand:hover .bloom{ opacity:.42; animation:breathe 3.4s ease-in-out infinite; }
  .brand:hover .hot{ opacity:1; stroke-dashoffset:0; }
  .brand:hover .gi{ opacity:1; filter:drop-shadow(0 0 9px var(--brand-glow)); }
  .brand:hover .txt{ color:var(--text); }
  .brand:hover .chip{ border-color:color-mix(in srgb, var(--brand) 40%, var(--line)); color:var(--text); }
  .brand:hover .enter{ border-color:var(--brand); background:color-mix(in srgb, var(--brand) 14%, transparent); }
  .brand:hover .enter .arr{ transform:translateX(5px); }
}
.brand:focus-visible{ border-color:var(--brand); outline:none; transform:translateY(-4px); }
.brand:focus-visible .brand-bg{ opacity:var(--card-img-hover,.78); transform:scale(1.06); }
.brand:focus-visible .bloom{ opacity:.42; }
.brand:focus-visible .hot{ opacity:1; stroke-dashoffset:0; }
.brand:focus-visible .gi{ opacity:1; filter:drop-shadow(0 0 9px var(--brand-glow)); }
.brand:focus-visible .txt{ color:var(--text); }
.brand:focus-visible .enter{ border-color:var(--brand); background:color-mix(in srgb, var(--brand) 14%, transparent); }

@media (hover:none){
  .brand{ border-color:color-mix(in srgb, var(--brand) 30%, var(--line)); }
  .brand .bloom{ opacity:.26; }
  .brand .hot{ opacity:1; stroke-dashoffset:0; }
  .brand .channel-label .gi{ opacity:1; }
  .brand .txt{ color:var(--text); }
  .brand .enter{ border-color:var(--brand); }
}
@keyframes breathe{ 0%,100%{ opacity:.40; } 50%{ opacity:.56; } }

/* ---------- footer / spec plate ---------- */
.site-footer{ border-top:1px solid var(--line); position:relative; z-index:1; }
.plate{ display:grid; grid-template-columns:repeat(3,1fr) auto; gap:34px 40px; padding:clamp(40px,6vh,64px) 0 28px; align-items:start; }
.plate .col h3{ margin:0 0 10px; }
.plate .col p{ margin:0; color:var(--text); font-size:.96rem; line-height:1.55; }
.plate .col p a:hover{ color:var(--hix); }
.plate .corp{ text-align:right; }
.plate .corp .mk{ font-weight:900; font-size:1.5rem; letter-spacing:.02em; }
.plate .corp .mk img{ height:30px; width:auto; display:inline-block; }
.legal{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; padding:18px 0 40px; border-top:1px solid var(--line); margin-top:8px; color:var(--faint); }

/* ---------- entrance motion ---------- */
.rise{ opacity:0; transform:translateY(20px); animation:rise .9s var(--ease) forwards; }
.d1{ animation-delay:.05s; } .d2{ animation-delay:.16s; } .d3{ animation-delay:.27s; }
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ---------- ignition intro: warm flare blooms behind the headline on load ---------- */
body.boot::before{ animation:warmup 1.7s var(--ease) both; }
@keyframes warmup{ from{ opacity:0; } to{ opacity:1; } }
.boot .hero::after{ content:""; position:absolute; inset:0; z-index:-1; pointer-events:none; background:radial-gradient(46% 54% at 30% 48%, rgba(255,108,42,.45), transparent 70%); opacity:0; animation:heatbloom 2.2s var(--ease) .2s 1; }
@keyframes heatbloom{ 0%{ opacity:0; } 32%{ opacity:.5; } 60%{ opacity:.95; } 100%{ opacity:0; } }

/* ---------- heat-flow: cards ignite one-by-one when scrolled into view ---------- */
.brands.lit .brand:nth-child(1) .hot{ animation:coilignite 1.7s var(--ease) .15s 1; }
.brands.lit .brand:nth-child(2) .hot{ animation:coilignite 1.7s var(--ease) .45s 1; }
.brands.lit .brand:nth-child(3) .hot{ animation:coilignite 1.7s var(--ease) .75s 1; }
.brands.lit .brand:nth-child(1) .bloom{ animation:bloomflash 1.7s var(--ease) .15s 1; }
.brands.lit .brand:nth-child(2) .bloom{ animation:bloomflash 1.7s var(--ease) .45s 1; }
.brands.lit .brand:nth-child(3) .bloom{ animation:bloomflash 1.7s var(--ease) .75s 1; }
.brands.lit .brand:nth-child(1) .gi{ animation:iconignite 1.7s var(--ease) .15s 1; }
.brands.lit .brand:nth-child(2) .gi{ animation:iconignite 1.7s var(--ease) .45s 1; }
.brands.lit .brand:nth-child(3) .gi{ animation:iconignite 1.7s var(--ease) .75s 1; }
@keyframes coilignite{ 0%{ opacity:0; stroke-dashoffset:100; } 28%{ opacity:1; } 55%{ opacity:1; stroke-dashoffset:0; } 100%{ opacity:0; stroke-dashoffset:0; } }
@keyframes bloomflash{ 0%{ opacity:0; } 38%{ opacity:.5; } 100%{ opacity:0; } }
@keyframes iconignite{ 0%{ opacity:.5; filter:none; } 38%{ opacity:1; filter:drop-shadow(0 0 9px var(--brand-glow)); } 100%{ opacity:.5; filter:none; } }

/* ---------- responsive ---------- */
@media (max-width:860px){
  .about .grid{ grid-template-columns:1fr; gap:34px; }
  .brands{ grid-template-columns:1fr; }
  .brand{ min-height:auto; }
  .coil{ width:min(240px,60%); margin:26px 0 22px; }
  .plate{ grid-template-columns:1fr 1fr; }
  .plate .corp{ grid-column:1 / -1; text-align:left; margin-top:6px; }
}
@media (max-width:520px){
  .social-panel{ right:0; width:min(290px, calc(100vw - 40px)); }
  .plate{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion:reduce){
  .spectrum::before{ animation:none; transform:scaleX(1); opacity:.85; }
  .spectrum::after{ display:none; }
  .rise,.reveal{ animation:none; transition:none; opacity:1; transform:none; }
  .brand:hover .bloom, .brand:focus-visible .bloom{ animation:none; }
  .brand-bg{ transform:none !important; }
  .coil .hot{ transition:opacity .3s; }
  .brand,.brand *{ transition-duration:.2s; }
  body.boot::before{ animation:none; opacity:1; }
  .boot .hero::after{ display:none; }
  .brands.lit .brand .hot, .brands.lit .brand .bloom, .brands.lit .brand .gi{ animation:none; }
  .hero-fx .blueprint{ animation:none; transform:none; }
  .hero-fx .blueprint .draw{ animation:none; stroke-dashoffset:0; opacity:1; }
  .hero-fx .embers{ display:none; }
}

/* WP admin bar offset */
.admin-bar .site-header{ }
