/* ================================================================
   정석컨설턴트 J.CONSULTANT v3.0 — Premium Redesign
   The Standard of Urbanism
   ================================================================ */
:root{
  --primary:#002C5F;--primary-d:#001B3D;--primary-m:#003E7E;--primary-l:#1A5AA0;
  --accent:#3CC0AC;--accent-d:#2EA899;--accent-l:#5ED4C2;
  --sky:#4A9FD9;--sky-pale:#E6F2FB;
  --white:#fff;--g50:#F7F9FB;--g100:#EEF2F6;--g200:#DDE4EB;--g300:#C1CCDA;
  --g400:#8E9FB0;--g500:#5F7082;--g600:#3D4F62;--g700:#263545;--g800:#14212E;
  --font:'Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;
  --max:1240px;--sec-py:120px;
  --sh-s:0 2px 8px rgba(0,44,95,.06);--sh-m:0 8px 32px rgba(0,44,95,.08);
  --sh-l:0 16px 56px rgba(0,44,95,.12);
  --r:12px;--rl:20px;
  --ease:cubic-bezier(.4,0,.2,1);--tr:all .35s var(--ease);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--font);color:var(--g600);line-height:1.75;background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:var(--tr)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{font-family:var(--font);cursor:pointer;border:0;background:0}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(255,255,255,0);transition:var(--tr)}
.header.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--g200)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:88px}
/* Logo dual mode: white (hero) ↔ color (scrolled) */
.logo{display:flex;align-items:center}
.logo-img{height:52px;transition:var(--tr)}
.logo-white{display:block}
.logo-color{display:none}
.header.scrolled .logo-white{display:none}
.header.scrolled .logo-color{display:block}
.header.scrolled .logo-img{height:44px}
.nav-links{display:flex;gap:6px}
.nav-link{padding:10px 20px;font-size:15px;font-weight:600;color:rgba(255,255,255,.85);border-radius:8px;letter-spacing:.01em;transition:var(--tr)}
.header.scrolled .nav-link{color:var(--g500)}
.nav-link:hover,.nav-link.active{color:var(--white);background:rgba(255,255,255,.12)}
.header.scrolled .nav-link:hover,.header.scrolled .nav-link.active{color:var(--primary);background:var(--sky-pale)}
.mob-btn{display:none;flex-direction:column;gap:5px;width:32px;height:32px;padding:4px}
.mob-btn span{display:block;height:2px;background:var(--white);border-radius:2px;transition:var(--tr)}
.header.scrolled .mob-btn span{background:var(--primary)}
.mob-btn.on span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.mob-btn.on span:nth-child(2){opacity:0}
.mob-btn.on span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-mob{display:none;background:var(--white);box-shadow:var(--sh-m)}
.nav-mob.on{display:block}
.nav-mob a{display:block;padding:16px 32px;font-size:15px;font-weight:600;color:var(--g600);border-bottom:1px solid var(--g100)}
.nav-mob a:hover{color:var(--primary);background:var(--sky-pale)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,27,61,.82) 0%,rgba(0,44,95,.65) 50%,rgba(0,62,126,.55) 100%)}
.hero-particles{position:absolute;inset:0;background-image:
  radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.12),transparent),
  radial-gradient(2px 2px at 80% 70%,rgba(60,192,172,.15),transparent),
  radial-gradient(1px 1px at 40% 80%,rgba(255,255,255,.08),transparent),
  radial-gradient(1px 1px at 60% 20%,rgba(74,159,217,.12),transparent);
  background-size:200px 200px,300px 300px,250px 250px,180px 180px;
  animation:particleDrift 30s linear infinite}
@keyframes particleDrift{from{transform:translate(0,0)}to{transform:translate(-50px,-50px)}}
.hero-content{position:relative;z-index:2;max-width:800px;padding-top:88px}
/* Hero slogan - English tagline (smaller, subtle) */
.hero-slogan{font-size:clamp(16px,2vw,22px);font-weight:700;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px;line-height:1.4;opacity:.9}
/* Hero Korean title - main headline (bigger, prominent) */
.hero h1{font-size:clamp(32px,5vw,58px);font-weight:800;color:var(--white);line-height:1.3;margin-bottom:24px;letter-spacing:-.03em}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--accent),var(--sky));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:clamp(15px,1.5vw,18px);color:rgba(255,255,255,.6);margin-bottom:44px;line-height:1.85}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:64px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-size:14.5px;font-weight:700;border-radius:10px;border:2px solid transparent;transition:var(--tr);letter-spacing:-.01em}
/* Hero primary button - frosted glass style */
.btn-hero-primary{background:rgba(255,255,255,.1);color:var(--white);border-color:rgba(255,255,255,.25);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.btn-hero-primary:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.2)}
.btn-hero-primary i{transition:transform .3s ease}
.btn-hero-primary:hover i{transform:translateX(4px)}
/* Accent button (for other sections) */
.btn-accent{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-accent:hover{background:var(--accent-l);border-color:var(--accent-l);transform:translateY(-3px);box-shadow:0 12px 32px rgba(60,192,172,.35)}
.btn-ghost{color:var(--white);border-color:rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6);transform:translateY(-3px)}
.btn-primary{background:var(--primary);color:var(--white);border-color:var(--primary);width:100%;justify-content:center;padding:16px;font-size:15px}
.btn-primary:hover{background:var(--primary-m);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,44,95,.25)}
.btn-block{display:flex}

/* Hero Stats */
.hero-stats{display:flex;gap:48px}
.h-stat{text-align:left}
.h-stat span.count{font-size:clamp(32px,3.5vw,46px);font-weight:800;color:var(--white);line-height:1}
.h-stat .unit{font-size:clamp(18px,2vw,28px);font-weight:700;color:var(--accent)}
.h-stat p{font-size:14px;color:rgba(255,255,255,.5);margin-top:6px;letter-spacing:.01em}

/* Scroll Hint */
.scroll-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.scroll-hint span{font-size:10px;letter-spacing:2.5px;color:rgba(255,255,255,.3);text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.2;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}

/* ===== SECTION COMMONS ===== */
.sec-label{display:inline-block;font-size:13px;font-weight:700;color:var(--accent);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:10px}
.sec-label--light{color:var(--accent)}
.sec-header{text-align:center;margin-bottom:64px}
.sec-title{font-size:clamp(30px,4vw,44px);font-weight:800;color:var(--primary);margin-bottom:16px;letter-spacing:-.03em;line-height:1.35}
.sec-title--light{color:var(--white)}
.sec-desc{font-size:17px;color:var(--g400);max-width:600px;margin:0 auto;line-height:1.75}
.sec-desc--light{color:rgba(255,255,255,.5)}
.sub-title{font-size:24px;font-weight:800;color:var(--primary);margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid var(--g200);display:flex;align-items:center;gap:12px}
.sub-title i{color:var(--accent);font-size:20px}

/* ===== VISION — Modern Fullscreen (Neutral Dark) ===== */
.vision-sec{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:140px 0 120px}
.vision-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed;transform:scale(1.05)}
.vision-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,18,18,.82) 0%,rgba(24,24,24,.58) 40%,rgba(12,12,12,.90) 100%)}

/* Vision Content Layout */
.vision-content{position:relative;z-index:2}

/* Vision Headline */
.vision-headline{text-align:center;margin-bottom:72px}
.vision-tag{display:inline-block;font-size:15px;font-weight:800;color:#fff;letter-spacing:4px;text-transform:uppercase;margin-bottom:20px;padding:12px 32px;border:2px solid rgba(255,255,255,.35);border-radius:30px;background:rgba(255,255,255,.08);backdrop-filter:blur(12px);text-shadow:0 1px 8px rgba(0,0,0,.5)}
.vision-title{font-size:clamp(32px,4.5vw,52px);font-weight:800;color:var(--white);line-height:1.3;margin-bottom:24px;letter-spacing:-.03em}
.vision-title em{font-style:normal;color:var(--accent)}
.vision-subtitle{font-size:18px;color:rgba(255,255,255,.85);line-height:1.85;max-width:560px;margin:0 auto;text-shadow:0 2px 12px rgba(0,0,0,.5)}

/* Vision Cards — Glass morphism image cards (neutral dark) */
.vision-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:64px}
.vision-card{position:relative;border-radius:20px;overflow:hidden;min-height:320px;display:flex;align-items:flex-end;transition:transform .5s var(--ease),box-shadow .5s var(--ease);cursor:default}
.vision-card:hover{transform:translateY(-10px);box-shadow:0 32px 64px rgba(0,0,0,.5)}
.vc-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.vision-card:hover .vc-bg{transform:scale(1.08)}
.vc-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.30) 0%,rgba(10,10,10,.70) 40%,rgba(5,5,5,.95) 100%);transition:background .5s var(--ease)}
.vision-card:hover .vc-overlay{background:linear-gradient(180deg,rgba(10,10,10,.20) 0%,rgba(10,10,10,.60) 35%,rgba(5,5,5,.93) 100%)}
.vc-inner{position:relative;z-index:2;padding:28px 28px;width:100%}
.vc-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.22);border-radius:16px;color:#fff;font-size:28px;margin-bottom:18px;backdrop-filter:blur(14px);transition:var(--tr);text-shadow:0 2px 12px rgba(60,192,172,.4)}
.vision-card:hover .vc-icon{background:rgba(60,192,172,.20);border-color:rgba(60,192,172,.35);transform:scale(1.1);color:var(--accent)}
.vc-num{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:2px;opacity:.8;margin-bottom:6px}
.vc-inner h3{font-size:26px;font-weight:800;color:var(--white);margin-bottom:10px;letter-spacing:-.02em;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.vc-inner p{font-size:15px;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:16px;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.vc-line{width:40px;height:2px;background:linear-gradient(90deg,var(--accent),transparent);margin-bottom:10px;transition:width .4s var(--ease)}
.vision-card:hover .vc-line{width:80px}
.vc-eng{font-size:12px;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:1.5px;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* Vision Keywords Bar (neutral dark) */
.vision-keywords{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:28px 36px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:16px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.vk-item{display:inline-flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:rgba(255,255,255,.7);transition:var(--tr);padding:6px 4px}
.vk-item:hover{color:var(--accent)}
.vk-item i{font-size:18px;color:rgba(255,255,255,.85);transition:var(--tr)}
.vk-item:hover i{color:var(--accent)}
.vk-divider{width:1px;height:18px;background:rgba(255,255,255,.12)}

/* ===== ABOUT — Premium Redesign ===== */
.about-sec{padding:0;background:var(--white)}

/* Hero Banner */
.about-hero{position:relative;height:380px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.about-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;background-attachment:fixed}
.about-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.25) 0%,rgba(0,0,0,.45) 100%)}
.about-hero-content{position:relative;z-index:2;text-align:center}
.about-hero-label{display:inline-block;font-size:13px;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:16px;padding:6px 20px;border:1.5px solid rgba(60,192,172,.35);border-radius:40px;background:rgba(60,192,172,.06)}
.about-hero-title{font-size:clamp(34px,5vw,52px);font-weight:800;color:var(--white);letter-spacing:-.03em;margin-bottom:14px}
.about-hero-sub{font-size:17px;color:rgba(255,255,255,.7);line-height:1.7;max-width:600px;margin:0 auto}

/* CEO & Company Info — Modern Premium */
.about-intro{padding:80px 0;background:var(--g50)}

/* ===== CEO + Company Overview — Unified Premium Section ===== */
.ceo-co-unified{position:relative;overflow:hidden}

/* Background Layers */
.ccu-bg{position:absolute;inset:0;background:linear-gradient(170deg,#000C1A 0%,var(--primary-d) 25%,var(--primary) 55%,#001530 85%,#000C1A 100%)}
.ccu-skyline{position:absolute;bottom:0;left:0;right:0;height:50%;
  background:
    linear-gradient(90deg,
      transparent 0%,
      transparent 3%, rgba(60,192,172,.04) 3%, rgba(60,192,172,.04) 3.5%, transparent 3.5%,
      transparent 8%, rgba(74,159,217,.03) 8%, rgba(74,159,217,.03) 9%, transparent 9%,
      transparent 14%, rgba(60,192,172,.05) 14%, rgba(60,192,172,.05) 15.5%, transparent 15.5%,
      transparent 20%, rgba(255,255,255,.02) 20%, rgba(255,255,255,.02) 21%, transparent 21%,
      transparent 28%, rgba(60,192,172,.04) 28%, rgba(60,192,172,.04) 29.5%, transparent 29.5%,
      transparent 35%, rgba(74,159,217,.03) 35%, rgba(74,159,217,.03) 36%, transparent 36%,
      transparent 42%, rgba(60,192,172,.06) 42%, rgba(60,192,172,.06) 43%, transparent 43%,
      transparent 50%, rgba(255,255,255,.02) 50%, rgba(255,255,255,.02) 51.5%, transparent 51.5%,
      transparent 58%, rgba(60,192,172,.04) 58%, rgba(60,192,172,.04) 59%, transparent 59%,
      transparent 65%, rgba(74,159,217,.05) 65%, rgba(74,159,217,.05) 66.5%, transparent 66.5%,
      transparent 72%, rgba(60,192,172,.03) 72%, rgba(60,192,172,.03) 73%, transparent 73%,
      transparent 80%, rgba(255,255,255,.03) 80%, rgba(255,255,255,.03) 81%, transparent 81%,
      transparent 88%, rgba(60,192,172,.04) 88%, rgba(60,192,172,.04) 89.5%, transparent 89.5%,
      transparent 95%, rgba(74,159,217,.03) 95%, rgba(74,159,217,.03) 96%, transparent 96%,
      transparent 100%
    );
  mask-image:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 100%);
  -webkit-mask-image:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 100%)
}
.ccu-grid-pattern{position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(60,192,172,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(60,192,172,.04) 1px,transparent 1px),
    linear-gradient(rgba(60,192,172,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(60,192,172,.018) 1px,transparent 1px);
  background-size:100px 100px,100px 100px,20px 20px,20px 20px;
  mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.35) 0%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.35) 0%,transparent 75%)
}
.ccu-glow{position:absolute;inset:0;background:
  radial-gradient(ellipse at 25% 70%,rgba(60,192,172,.1) 0%,transparent 50%),
  radial-gradient(ellipse at 75% 30%,rgba(74,159,217,.07) 0%,transparent 50%)
}
.ccu-inner{position:relative;z-index:2;padding:100px 0 80px}

/* ── CEO Message Part ── */
.ccu-ceo{max-width:800px;margin:0 auto;text-align:center}

/* Badge */
.ccu-badge{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:48px}
.ccu-badge-line{width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--accent));flex-shrink:0}
.ccu-badge-line:last-child{background:linear-gradient(90deg,var(--accent),transparent)}
.ccu-badge-text{font-size:13px;font-weight:800;letter-spacing:4px;color:var(--accent)}

/* Slogan */
.ccu-slogan{font-size:clamp(28px,3.5vw,42px);font-weight:900;color:var(--white);line-height:1.5;letter-spacing:-.02em;margin-bottom:20px;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.ccu-highlight{color:var(--accent);position:relative}
.ccu-highlight::after{content:'';position:absolute;left:0;bottom:2px;width:100%;height:3px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:2px;opacity:.4}

/* Name Bar */
.ccu-name-bar{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:40px}
.ccu-name-line{flex:1;max-width:80px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15))}
.ccu-name-line:last-child{background:linear-gradient(90deg,rgba(255,255,255,.15),transparent)}
.ccu-name-info{font-size:15px;color:rgba(255,255,255,.5);letter-spacing:.5px;white-space:nowrap}
.ccu-name-info strong{font-size:18px;font-weight:800;color:var(--white);margin-left:4px}

/* Tabs */
.ccu-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap;justify-content:center}
.ccu-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;font-size:13px;font-weight:700;font-family:var(--font);color:rgba(255,255,255,.45);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:28px;cursor:pointer;transition:var(--tr)}
.ccu-tab:hover{color:rgba(255,255,255,.7);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.ccu-tab.active{color:var(--primary-d);background:var(--accent);border-color:var(--accent);box-shadow:0 4px 20px rgba(60,192,172,.3)}
.ccu-tab i{font-size:12px}

/* Tab Content */
.ccu-tab-content{display:none;animation:ccuFadeIn .5s var(--ease);text-align:left}
.ccu-tab-content.active{display:block}
.ccu-tab-content p{font-size:19px;color:rgba(255,255,255,.85);line-height:2.05;margin-bottom:22px;letter-spacing:.02em}
.ccu-tab-content p:last-child{margin-bottom:0}
.ccu-tab-content p strong{color:var(--white);font-weight:800;text-shadow:0 0 12px rgba(60,192,172,.2)}
@keyframes ccuFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── Divider ── */
.ccu-divider{max-width:960px;margin:64px auto 56px;opacity:.8}

/* ── Company Overview Part ── */
.ccu-company{max-width:960px;margin:0 auto}

/* Header */
.ccu-co-header{text-align:center;margin-bottom:40px}
.ccu-co-label{display:block;font-size:12px;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:10px;text-transform:uppercase}
.ccu-co-title{font-size:clamp(28px,3.5vw,38px);font-weight:900;color:var(--white);letter-spacing:-.02em}

/* Layout: Seal + Cards side-by-side on desktop */
.ccu-co-layout{display:grid;grid-template-columns:140px 1fr;gap:36px;align-items:start}

/* Seal Badge */
.ccu-seal{position:sticky;top:120px}
.ccu-seal-ring{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}
.ccu-seal-svg{position:absolute;inset:0;width:100%;height:100%;animation:ccuSealSpin 30s linear infinite}
@keyframes ccuSealSpin{to{transform:rotate(360deg)}}
.ccu-seal-inner{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.ccu-seal-inner i{font-size:22px;color:var(--accent);margin-bottom:4px}
.ccu-seal-inner strong{font-size:8px;font-weight:800;letter-spacing:2.5px;color:var(--accent);text-transform:uppercase}
.ccu-seal-inner span{font-size:11px;font-weight:700;color:rgba(255,255,255,.7);line-height:1.3}

/* Cards Grid */
.ccu-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* Card Base */
.ccu-card{position:relative;background:rgba(255,255,255,.04);border-radius:18px;overflow:hidden;transition:all .4s var(--ease);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.ccu-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.07);border-color:rgba(60,192,172,.3);box-shadow:0 16px 48px rgba(0,0,0,.25)}

/* Card Glow — hover accent line */
.ccu-card-glow{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .4s var(--ease)}
.ccu-card:hover .ccu-card-glow{opacity:1}

/* Card Content */
.ccu-card-content{padding:28px 24px;position:relative}
.ccu-card-content--row{display:flex;align-items:center;gap:18px}

/* Icons */
.ccu-card-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:14px;margin-bottom:16px;transition:all .4s var(--ease);flex-shrink:0;border:1px solid transparent}
.ccu-card-content--row .ccu-card-icon{margin-bottom:0}
.ccu-card:hover .ccu-card-icon{transform:scale(1.08)}

/* Icon Color Variants */
.ccu-icon--navy{background:rgba(0,44,95,.2);color:rgba(130,170,220,1);border-color:rgba(0,44,95,.3)}
.ccu-card:hover .ccu-icon--navy{background:rgba(0,44,95,.35);border-color:rgba(60,192,172,.2)}

.ccu-icon--teal{background:rgba(60,192,172,.12);color:#5ADBC5;border-color:rgba(60,192,172,.18)}
.ccu-card:hover .ccu-icon--teal{background:rgba(60,192,172,.22);border-color:rgba(60,192,172,.35)}

.ccu-icon--sky{background:rgba(74,159,217,.12);color:#6DB8E8;border-color:rgba(74,159,217,.18)}
.ccu-card:hover .ccu-icon--sky{background:rgba(74,159,217,.22);border-color:rgba(74,159,217,.3)}

.ccu-icon--amber{background:rgba(230,180,70,.1);color:#E8C050;border-color:rgba(230,180,70,.15)}
.ccu-card:hover .ccu-icon--amber{background:rgba(230,180,70,.2);border-color:rgba(230,180,70,.3)}

.ccu-icon--emerald{background:rgba(50,190,110,.1);color:#44D68A;border-color:rgba(50,190,110,.15)}
.ccu-card:hover .ccu-icon--emerald{background:rgba(50,190,110,.2);border-color:rgba(50,190,110,.3)}

.ccu-icon--violet{background:rgba(130,100,220,.1);color:#A088F0;border-color:rgba(130,100,220,.15)}
.ccu-card:hover .ccu-icon--violet{background:rgba(130,100,220,.2);border-color:rgba(130,100,220,.3)}

.ccu-icon--rose{background:rgba(230,80,90,.1);color:#F06070;border-color:rgba(230,80,90,.15)}
.ccu-card:hover .ccu-icon--rose{background:rgba(230,80,90,.18);border-color:rgba(230,80,90,.28)}

/* Card Typography */
.ccu-card-label{display:block;font-size:11px;font-weight:700;letter-spacing:2px;color:var(--accent);margin-bottom:6px;text-transform:uppercase}
.ccu-card-value{display:block;font-size:17px;font-weight:800;color:rgba(255,255,255,.9);letter-spacing:-.01em;line-height:1.4}
.ccu-card-value--lg{font-size:22px;color:var(--white)}
.ccu-card-sub{display:block;font-size:13px;font-weight:600;color:rgba(255,255,255,.4);margin-top:4px;letter-spacing:.5px}
.ccu-card-value a{color:rgba(255,255,255,.9);text-decoration:none;transition:var(--tr)}
.ccu-card-value a:hover{color:var(--accent)}

/* Card Variants */
.ccu-card--featured .ccu-card-content{padding:32px 28px}
.ccu-card--wide{grid-column:span 2}
.ccu-card--full{grid-column:1/-1}

/* Address + Map */
.ccu-addr{flex:1;min-width:0}
.ccu-map-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;font-size:13px;font-weight:700;font-family:var(--font);color:var(--white);background:rgba(60,192,172,.2);border:1px solid rgba(60,192,172,.3);border-radius:10px;white-space:nowrap;transition:var(--tr);flex-shrink:0;text-decoration:none}
.ccu-map-btn:hover{background:var(--accent);color:var(--primary-d);transform:translateY(-2px);box-shadow:0 4px 16px rgba(60,192,172,.3);border-color:var(--accent)}
.ccu-map-btn i{font-size:11px}

/* ===== CI Section v2 — Architecture Competition Board ===== */
.ci-v2{position:relative;padding:110px 0;overflow:hidden;background:var(--primary-d)}

/* Background Layers */
.ci-v2-bg{position:absolute;inset:0;background:linear-gradient(170deg,#000F1F 0%,var(--primary-d) 40%,#001830 100%)}
.ci-v2-grid-layer{position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(60,192,172,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(60,192,172,.035) 1px,transparent 1px),
    linear-gradient(rgba(60,192,172,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(60,192,172,.015) 1px,transparent 1px);
  background-size:120px 120px,120px 120px,24px 24px,24px 24px
}
.ci-v2-geo-lines{position:absolute;inset:0;pointer-events:none}
.ci-v2-geo-svg{width:100%;height:100%}
.ci-v2-inner{position:relative;z-index:2}

/* Header */
.ci-v2-header{text-align:center;margin-bottom:64px}
.ci-v2-label{display:inline-block;font-size:12px;font-weight:700;letter-spacing:3.5px;color:var(--accent);margin-bottom:14px;text-transform:uppercase}
.ci-v2-title{font-size:clamp(30px,4vw,44px);font-weight:900;color:var(--white);letter-spacing:-.02em;margin-bottom:18px}
.ci-v2-desc{font-size:16.5px;color:rgba(255,255,255,.6);line-height:1.85;max-width:640px;margin:0 auto 28px}
.ci-v2-desc strong{color:var(--accent);font-weight:700}

/* Slogan */
.ci-v2-slogan{font-size:clamp(18px,2.2vw,24px);font-weight:700;color:rgba(255,255,255,.85);letter-spacing:.01em;line-height:1.6}
.ci-v2-slogan strong{color:var(--accent);font-weight:800}
.ci-v2-slogan-mark{font-size:1.3em;color:var(--accent);opacity:.5;font-family:Georgia,serif;vertical-align:-.05em}

/* Section Sub-Title */
.ci-v2-sec-title{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;letter-spacing:2px;color:rgba(255,255,255,.4);text-transform:uppercase;margin-bottom:28px}
.ci-v2-sec-title svg{flex-shrink:0;opacity:.6}

/* Logo Guide Cards */
.ci-v2-logos{margin-bottom:72px}
.ci-v2-logo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.ci-v2-logo-card{position:relative;border-radius:20px;overflow:hidden;transition:all .45s var(--ease)}
.ci-v2-logo-card:hover{transform:translateY(-8px)}

.ci-v2-logo-card-tag{position:absolute;top:16px;left:16px;font-size:10px;font-weight:800;letter-spacing:2px;padding:4px 12px;border-radius:6px;text-transform:uppercase;z-index:3}

/* Dark Card */
.ci-v2-logo-card--dark{background:var(--primary);border:1px solid rgba(60,192,172,.1)}
.ci-v2-logo-card--dark .ci-v2-logo-card-tag{color:var(--accent);background:rgba(60,192,172,.12);border:1px solid rgba(60,192,172,.2)}
.ci-v2-logo-card--dark:hover{border-color:var(--accent);box-shadow:0 16px 48px rgba(60,192,172,.15)}

/* Light Card */
.ci-v2-logo-card--light{background:rgba(255,255,255,.95);border:1px solid rgba(0,44,95,.08)}
.ci-v2-logo-card--light .ci-v2-logo-card-tag{color:var(--primary);background:rgba(0,44,95,.06);border:1px solid rgba(0,44,95,.1)}
.ci-v2-logo-card--light:hover{border-color:var(--sky);box-shadow:0 16px 48px rgba(0,44,95,.12)}
.ci-v2-logo-card--light .ci-v2-logo-meta strong{color:var(--primary)}
.ci-v2-logo-card--light .ci-v2-logo-meta span{color:var(--g400)}
.ci-v2-logo-card--light .ci-v2-logo-spec{color:var(--g300)!important}

/* Gradient Card */
.ci-v2-logo-card--gradient{background:linear-gradient(150deg,var(--primary),var(--primary-m));border:1px solid rgba(60,192,172,.12)}
.ci-v2-logo-card--gradient .ci-v2-logo-card-tag{color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15)}
.ci-v2-logo-card--gradient:hover{border-color:var(--accent);box-shadow:0 16px 48px rgba(60,192,172,.15)}

/* Logo Image Area */
.ci-v2-logo-img-wrap{padding:44px 32px;display:flex;align-items:center;justify-content:center;min-height:140px}
.ci-v2-logo-img{max-height:80px;width:auto;object-fit:contain;transition:all .45s var(--ease);filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}
.ci-v2-logo-img--symbol{max-height:88px}
.ci-v2-logo-card:hover .ci-v2-logo-img{transform:scale(1.08);filter:drop-shadow(0 4px 16px rgba(0,0,0,.25))}

/* Logo Meta */
.ci-v2-logo-meta{padding:20px 24px;border-top:1px solid rgba(255,255,255,.06)}
.ci-v2-logo-meta strong{display:block;font-size:14px;font-weight:700;color:var(--white);margin-bottom:4px}
.ci-v2-logo-meta span{display:block;font-size:12px;color:rgba(255,255,255,.45);line-height:1.5}
.ci-v2-logo-spec{font-size:11px!important;font-family:'Courier New',monospace;letter-spacing:.5px;color:rgba(255,255,255,.3)!important;margin-top:6px}

/* Symbol Meaning Cards */
.ci-v2-meaning-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.ci-v2-mean-card{background:rgba(255,255,255,.04);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:36px 28px;transition:all .4s var(--ease)}
.ci-v2-mean-card:hover{background:rgba(255,255,255,.08);border-color:rgba(60,192,172,.2);transform:translateY(-4px)}

/* Meaning Icon — Color Variants */
.ci-v2-mean-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:16px;margin-bottom:20px;transition:all .4s var(--ease)}
.ci-v2-mean-card:hover .ci-v2-mean-icon{transform:scale(1.1)}

.ci-v2-mean-icon--teal{background:rgba(60,192,172,.1);color:var(--accent);border:1px solid rgba(60,192,172,.15)}
.ci-v2-mean-icon--sky{background:rgba(74,159,217,.1);color:var(--sky);border:1px solid rgba(74,159,217,.15)}
.ci-v2-mean-icon--navy{background:rgba(255,255,255,.06);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.1)}

.ci-v2-mean-card h5{font-size:17px;font-weight:800;color:var(--white);margin-bottom:12px}
.ci-v2-mean-card p{font-size:14.5px;color:rgba(255,255,255,.55);line-height:1.85}
.ci-v2-mean-card p strong{color:var(--accent);font-weight:700}

/* Infographic Items */
.ci-v2-info-items{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.ci-v2-info-item{display:flex;align-items:center;gap:14px;font-size:14px;color:rgba(255,255,255,.55);line-height:1.5}
.ci-v2-info-item strong{color:var(--accent);font-weight:700}
.ci-v2-info-shape{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:300;color:var(--accent);background:rgba(60,192,172,.08);border:1px solid rgba(60,192,172,.12);border-radius:8px;flex-shrink:0;font-family:'Courier New',monospace}

/* Photo Break */
.about-photo-break{width:100%;overflow:hidden;line-height:0;position:relative}
.about-photo-break--1{height:280px}
.about-photo-break--2{height:240px}
.about-photo-img{width:100%;height:100%;object-fit:cover;display:block}

/* CI Font */
.about-ci-font{max-width:600px;margin:0 auto}
.ci-font-box{display:flex;align-items:center;gap:20px;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:24px 28px}
.ci-font-box i{font-size:28px;color:var(--accent);flex-shrink:0}
.ci-font-box h5{font-size:14px;font-weight:700;color:var(--white);margin-bottom:4px}
.ci-font-box p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.6}

/* Org Section — Premium Dark with BG Image */
.about-org-wrap{padding:100px 0;position:relative;overflow:hidden}
.org-bg-img{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.org-bg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(8,14,24,.88),rgba(12,20,36,.82))}
.org-bg-pattern{position:absolute;inset:0;background-image:
  radial-gradient(rgba(60,192,172,.05) 1px,transparent 1px),
  radial-gradient(rgba(74,159,217,.03) 1px,transparent 1px);
  background-size:32px 32px,48px 48px;background-position:0 0,16px 16px;pointer-events:none}
.about-org-header,.about-hist-header{text-align:center;margin-bottom:56px;position:relative;z-index:2}
.about-sub-label{display:block;font-size:13px;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:10px}
.about-sub-title-org{font-size:clamp(30px,4.5vw,46px);font-weight:800;color:var(--white);letter-spacing:-.02em;margin-bottom:16px;text-shadow:0 2px 20px rgba(0,0,0,.4)}
.org-desc{font-size:17px;color:rgba(255,255,255,.65);line-height:1.75;text-shadow:0 1px 8px rgba(0,0,0,.3)}

/* Org v3 — CEO */
.org-v3{max-width:960px;margin:0 auto;position:relative;z-index:2}
.org-v3-ceo{display:flex;justify-content:center;margin-bottom:0;position:relative}
.org-v3-ceo-glow{position:absolute;width:260px;height:260px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(60,192,172,.18) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:orgGlow 4s ease-in-out infinite alternate}
@keyframes orgGlow{0%{opacity:.5;transform:translate(-50%,-50%) scale(.9)}100%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}
.org-v3-ceo-card{position:relative;display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,rgba(0,44,95,.95),rgba(0,62,126,.85));border:1.5px solid rgba(60,192,172,.35);border-radius:18px;padding:22px 44px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 40px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.08);transition:var(--tr)}
.org-v3-ceo-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 16px 56px rgba(60,192,172,.2)}
.org-v3-ceo-avatar{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--sky));display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--white);flex-shrink:0;box-shadow:0 4px 20px rgba(60,192,172,.35)}
.org-v3-ceo-role{display:block;font-size:11px;font-weight:700;letter-spacing:2.5px;color:var(--accent);margin-bottom:3px;text-transform:uppercase}
.org-v3-ceo-info h4{font-size:22px;font-weight:800;color:var(--white);text-shadow:0 1px 6px rgba(0,0,0,.3)}

/* SVG Connector */
.org-v3-connector{max-width:800px;margin:0 auto;height:60px;position:relative;z-index:2}
.org-v3-svg{width:100%;height:100%}
.org-svg-line{stroke:rgba(60,192,172,.5);stroke-width:2.5}
.org-svg-dot{fill:var(--accent);filter:drop-shadow(0 0 6px rgba(60,192,172,.7))}

/* Department Cards */
.org-v3-depts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:2}
.org-v3-dept{background:rgba(255,255,255,.06);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:32px 24px;transition:var(--tr);position:relative;overflow:hidden}
.org-v3-dept::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--sky));opacity:0;transition:var(--tr)}
.org-v3-dept:hover{background:rgba(255,255,255,.12);border-color:rgba(60,192,172,.35);transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.35)}
.org-v3-dept:hover::after{opacity:1}
.org-v3-dept-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.org-v3-dept-num{font-size:40px;font-weight:900;background:linear-gradient(135deg,rgba(60,192,172,.25),rgba(74,159,217,.15));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-2px;line-height:1}
.org-v3-dept-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(60,192,172,.15);color:var(--accent);font-size:24px;border:1px solid rgba(60,192,172,.25);transition:var(--tr);box-shadow:0 2px 12px rgba(60,192,172,.1)}
.org-v3-dept:hover .org-v3-dept-icon{background:linear-gradient(135deg,var(--accent),var(--sky));color:var(--white);border-color:transparent;box-shadow:0 6px 24px rgba(60,192,172,.4)}
.org-v3-dept h5{font-size:19px;font-weight:800;color:var(--white);margin-bottom:5px;text-shadow:0 1px 6px rgba(0,0,0,.3)}
.org-v3-dept-eng{font-size:11px;font-weight:700;letter-spacing:1.5px;color:rgba(255,255,255,.4);text-transform:uppercase;margin-bottom:16px}
.org-v3-dept-divider{height:1px;background:linear-gradient(90deg,rgba(60,192,172,.3),transparent);margin-bottom:16px}
.org-v3-dept ul{display:flex;flex-direction:column;gap:10px}
.org-v3-dept li{font-size:15px;font-weight:500;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:10px;transition:var(--tr)}
.org-v3-dept:hover li{color:rgba(255,255,255,.9)}
.org-v3-dept li i{font-size:9px;color:var(--accent);opacity:.7;flex-shrink:0}

/* History Section */
.about-history-wrap{position:relative;padding:100px 0;overflow:hidden}
.about-hist-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.about-hist-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.35) 0%,rgba(0,10,25,.55) 100%)}
.about-hist-inner{position:relative;z-index:2}
.about-hist-label{display:block;font-size:12px;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:8px}
.about-hist-title{font-size:clamp(24px,3vw,32px);font-weight:800;color:var(--white);display:flex;align-items:center;justify-content:center;gap:12px}
.about-hist-title i{font-size:24px;color:var(--accent)}

/* Timeline v2 */
.hist-timeline-v2{position:relative;max-width:800px;margin:0 auto;padding:32px 0}
.htv2-line{position:absolute;top:0;bottom:0;left:50%;width:3px;background:linear-gradient(to bottom,var(--accent),rgba(255,255,255,.15),var(--accent));border-radius:2px;transform:translateX(-50%)}
.htv2-item{display:flex;align-items:flex-start;margin-bottom:48px;position:relative;padding-right:calc(50% + 40px)}
.htv2-item.htv2-right{padding-right:0;padding-left:calc(50% + 40px);flex-direction:row-reverse}
.htv2-item.htv2-right .htv2-card{text-align:left}
.htv2-card{flex:1;text-align:right;background:rgba(0,10,25,.35);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:24px;transition:var(--tr)}
.htv2-card:hover{background:rgba(0,10,25,.5);border-color:rgba(60,192,172,.25)}
.htv2-year{position:absolute;left:50%;transform:translateX(-50%);top:0;font-size:14px;font-weight:800;color:var(--white);background:linear-gradient(135deg,var(--accent),var(--accent-d));padding:6px 20px;border-radius:20px;z-index:2;white-space:nowrap;box-shadow:0 4px 12px rgba(60,192,172,.25)}
.htv2-dot{position:absolute;left:50%;top:34px;width:14px;height:14px;background:var(--accent);border:3px solid rgba(30,30,30,.8);border-radius:50%;transform:translateX(-50%);z-index:2;box-shadow:0 0 0 4px rgba(60,192,172,.15)}
.htv2-card h4{font-size:17px;font-weight:700;color:var(--white);margin-bottom:10px}
.htv2-card ul{display:flex;flex-direction:column;gap:6px}
.htv2-card li{font-size:14px;color:rgba(255,255,255,.75);line-height:1.65;position:relative;padding-left:16px}
.htv2-card li::before{content:'';position:absolute;left:0;top:9px;width:6px;height:6px;background:var(--accent);border-radius:50%}
.htv2-item.htv2-right .htv2-card li{padding-left:16px;padding-right:0}

/* ===== BUSINESS ===== */
.biz-sec{background:var(--white)}
.biz-hero{position:relative;height:340px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.biz-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.biz-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,15,18,.7),rgba(20,22,28,.55))}
.biz-hero-inner{position:relative;z-index:2;text-align:center}
.biz-hero-inner h2{font-size:clamp(32px,4.5vw,48px);font-weight:800;color:var(--white);margin-bottom:12px;letter-spacing:-.03em}
.biz-hero-inner p{font-size:18px;color:rgba(255,255,255,.65)}

/* Tabs */
.biz-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:-40px auto 48px;position:relative;z-index:3;background:var(--white);padding:16px 20px;border-radius:var(--rl);box-shadow:var(--sh-l);max-width:900px}
.biz-tab{padding:12px 24px;font-size:14.5px;font-weight:700;color:var(--g500);border-radius:10px;transition:var(--tr);display:flex;align-items:center;gap:8px}
.biz-tab i{font-size:15px}
.biz-tab:hover{color:var(--primary);background:var(--sky-pale)}
.biz-tab.active{color:var(--white);background:var(--primary);box-shadow:0 4px 16px rgba(0,44,95,.2)}

/* Panels */
.biz-panels{margin-bottom:72px}
.biz-panel{display:none;grid-template-columns:1fr 1fr;gap:0;background:var(--white);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh-l);border:1px solid var(--g100);min-height:360px}
.biz-panel.active{display:grid;animation:panelIn .5s var(--ease)}
@keyframes panelIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.bp-img{position:relative;overflow:hidden;min-height:360px}
.bp-img-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s var(--ease)}
.biz-panel:hover .bp-img-bg{transform:scale(1.05)}
.bp-img-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,15,18,.25),rgba(20,22,28,.4))}
.bp-img-label{position:absolute;bottom:24px;left:24px;font-size:13px;font-weight:700;color:var(--white);letter-spacing:2.5px;text-transform:uppercase;opacity:.55}
.bp-detail{padding:48px;display:flex;flex-direction:column;justify-content:center}
.bp-detail h3{font-size:28px;font-weight:800;color:var(--primary);margin-bottom:16px;letter-spacing:-.02em}
.bp-detail>p{font-size:16px;color:var(--g500);line-height:1.85;margin-bottom:24px}
.bp-tags{display:flex;flex-wrap:wrap;gap:8px}
.bp-tags span{padding:8px 16px;font-size:13.5px;font-weight:600;color:var(--primary);background:var(--sky-pale);border-radius:8px;border:1px solid var(--g200)}

/* Process Flow */
.process-section{padding:56px 48px;background:var(--g50);border-radius:var(--rl)}
.process-flow{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-top:24px}
.pf-step{flex:1;text-align:center;max-width:160px;padding:0 6px}
.pf-icon{width:72px;height:72px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;background:var(--white);border:3px solid var(--g200);border-radius:50%;font-size:26px;color:var(--primary);box-shadow:var(--sh-s);transition:var(--tr)}
.pf-step:hover .pf-icon{background:var(--primary);color:var(--white);border-color:var(--primary);transform:scale(1.1)}
.pf-num{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:1px;margin-bottom:6px}
.pf-step h4{font-size:14.5px;font-weight:800;color:var(--primary);margin-bottom:4px}
.pf-step p{font-size:13px;color:var(--g400);line-height:1.55}
.pf-arrow{display:flex;align-items:center;padding-top:28px;color:var(--g300);font-size:14px}

/* ===== PORTFOLIO ===== */
.port-sec{padding:var(--sec-py) 0;background:var(--primary-d);position:relative;overflow:hidden}
.port-sec::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.02) 1px,transparent 1px);background-size:24px 24px}

.port-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:56px;position:relative;z-index:1}
.ps-item{text-align:center;padding:32px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);transition:var(--tr)}
.ps-item:hover{background:rgba(255,255,255,.08);transform:translateY(-4px)}
.ps-item .count{font-size:clamp(32px,3.5vw,42px);font-weight:800;color:var(--white);line-height:1}
.ps-unit{font-size:20px;font-weight:700;color:var(--accent)}
.ps-item p{font-size:14px;color:rgba(255,255,255,.5);margin-top:8px}

.port-filter{display:flex;justify-content:center;gap:10px;margin-bottom:40px;flex-wrap:wrap;position:relative;z-index:1}
.pf-btn{padding:10px 28px;font-size:14px;font-weight:700;color:rgba(255,255,255,.5);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:28px;transition:var(--tr);font-family:var(--font)}
.pf-btn:hover{color:var(--white);background:rgba(255,255,255,.1)}
.pf-btn.active{color:var(--primary);background:var(--accent);border-color:var(--accent)}

.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:1}
.port-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:28px;transition:var(--tr);display:flex;flex-direction:column}
.port-card:hover{background:rgba(255,255,255,.1);border-color:var(--accent);transform:translateY(-4px)}
.port-card.hide{display:none}
.pc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.pc-year{font-size:12px;font-weight:800;color:var(--accent);background:rgba(60,192,172,.12);padding:4px 12px;border-radius:6px}
.pc-cat{font-size:12px;font-weight:600;color:rgba(255,255,255,.45);padding:4px 10px;border:1px solid rgba(255,255,255,.1);border-radius:6px}
.port-card h4{font-size:16px;font-weight:700;color:var(--white);line-height:1.55;margin-bottom:12px;flex:1}
.pc-client{font-size:13.5px;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:6px}
.pc-client i{color:var(--accent);font-size:12px}

/* Port Card Link variant */
.port-card--link{cursor:pointer;text-decoration:none;color:inherit}
.port-card--link:hover{border-color:var(--accent);background:rgba(255,255,255,.12);transform:translateY(-6px);box-shadow:0 12px 36px rgba(0,0,0,.2)}
.pc-detail-link{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:12px;font-weight:700;color:var(--accent);opacity:0;transform:translateX(-6px);transition:all .35s var(--ease)}
.port-card--link:hover .pc-detail-link{opacity:1;transform:translateX(0)}
.pc-detail-link i{font-size:10px;transition:transform .3s var(--ease)}
.port-card--link:hover .pc-detail-link i{transform:translateX(3px)}

/* Status badge in card */
.pc-status{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 10px;border-radius:12px}
.pc-status--active{color:#22C55E;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.2)}
.pc-status--active i{font-size:6px;animation:pcPulseDot 2s infinite}
@keyframes pcPulseDot{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== PORTFOLIO TABLE ===== */
.port-table-sec{padding:var(--sec-py) 0;background:var(--primary-d);position:relative;overflow:hidden}
.port-table-sec::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.02) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}
.port-table-sec .sec-header{position:relative;z-index:1;text-align:center;margin-bottom:48px}
.sec-title--light{color:var(--white)}
.sec-desc--light{color:rgba(255,255,255,.5);font-size:16px;margin-top:8px}
.sec-label--light{color:var(--accent)}

/* Filters */
.pt-filters{display:flex;justify-content:center;gap:10px;margin-bottom:36px;position:relative;z-index:1;flex-wrap:wrap}
.pt-filter{padding:10px 28px;font-size:14px;font-weight:700;color:rgba(255,255,255,.5);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:28px;cursor:pointer;transition:var(--tr);font-family:var(--font);display:inline-flex;align-items:center;gap:8px}
.pt-filter:hover{color:var(--white);background:rgba(255,255,255,.1)}
.pt-filter.active{color:var(--primary-d);background:var(--accent);border-color:var(--accent)}
.pt-count{font-size:12px;font-weight:800;padding:2px 8px;border-radius:12px;background:rgba(255,255,255,.15);line-height:1.4}
.pt-filter.active .pt-count{background:rgba(0,28,63,.2)}

/* Table wrap */
.pt-wrap{position:relative;z-index:1;border-radius:var(--rl);overflow:hidden;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(4px)}
.pt-table{width:100%;border-collapse:collapse;table-layout:fixed}
.pt-table thead{background:rgba(255,255,255,.06)}
.pt-table th{padding:16px 20px;font-size:13px;font-weight:800;color:var(--accent);text-align:left;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}
.pt-th-no{width:60px;text-align:center}
.pt-th-client{width:100px;text-align:center}
.pt-th-name{width:auto}
.pt-th-field{width:220px}

.pt-table tbody tr{transition:background .25s ease;border-bottom:1px solid rgba(255,255,255,.04)}
.pt-table tbody tr:hover{background:rgba(60,192,172,.06)}
.pt-table tbody tr:last-child{border-bottom:none}
.pt-table tbody tr.pt-hide{display:none}
.pt-table td{padding:14px 20px;font-size:14.5px;color:rgba(255,255,255,.7);vertical-align:middle}
.pt-no{text-align:center;font-weight:700;color:rgba(255,255,255,.3);font-size:13px}

/* Badges */
.pt-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 14px;border-radius:6px;font-size:12px;font-weight:700;min-width:48px}
.pt-badge--public{color:#4A9FD9;background:rgba(74,159,217,.12);border:1px solid rgba(74,159,217,.2)}
.pt-badge--private{color:#E8914F;background:rgba(232,145,79,.1);border:1px solid rgba(232,145,79,.18)}

.pt-name{font-weight:600;color:rgba(255,255,255,.85);line-height:1.55}
.pt-field{font-size:13px;color:rgba(255,255,255,.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Table summary bar */
.pt-summary{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.06);position:relative;z-index:1}
.pt-summary-text{font-size:13px;color:rgba(255,255,255,.4)}
.pt-summary-text strong{color:var(--accent);font-weight:800}

/* ===== CONTACT ===== */
.contact-sec{padding:var(--sec-py) 0;background:var(--g50)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.map-card{width:100%;height:280px;border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh-m)}
.map-link-box{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--primary),var(--primary-m));transition:var(--tr);text-align:center;padding:32px;position:relative;overflow:hidden}
.map-link-box::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:40px 40px}
.map-link-box:hover{background:linear-gradient(135deg,var(--primary-m),var(--primary))}
.map-link-box i.fa-map-marked-alt{font-size:40px;color:var(--accent);margin-bottom:14px}
.map-link-box p{color:rgba(255,255,255,.7);font-size:15.5px;line-height:1.65;margin-bottom:16px}
.map-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:var(--accent);color:var(--white);border-radius:8px;font-size:14px;font-weight:700;transition:var(--tr)}
.map-link-box:hover .map-cta{background:var(--accent-l);transform:translateY(-2px)}
.contact-info-cards{display:flex;flex-direction:column;gap:12px;margin-top:20px}
.ci-card{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;background:var(--white);border-radius:var(--r);box-shadow:var(--sh-s);border:1px solid var(--g100)}
.ci-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--sky-pale);color:var(--primary);border-radius:10px;font-size:15px;flex-shrink:0}
.ci-card strong{font-size:14px;color:var(--primary);display:block;margin-bottom:2px}
.ci-card p{font-size:15px;color:var(--g500);line-height:1.55}

/* Form */
.form-card{background:var(--white);padding:48px;border-radius:var(--rl);box-shadow:var(--sh-m);border:1px solid var(--g100)}
.form-card>h3{font-size:26px;font-weight:800;color:var(--primary);margin-bottom:8px}
.form-sub{font-size:15px;color:var(--g400);margin-bottom:32px}
.fg{margin-bottom:20px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg label{display:block;font-size:14px;font-weight:700;color:var(--g600);margin-bottom:8px}
.req{color:#E63946}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 16px;font-size:15px;font-family:var(--font);color:var(--g600);background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);transition:var(--tr);outline:0}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--sky);background:var(--white);box-shadow:0 0 0 4px rgba(74,159,217,.1)}
.fg textarea{resize:vertical;min-height:120px}
.chk{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--g500);cursor:pointer;margin-bottom:24px}
.chk input{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}
.f-success{display:none;text-align:center;padding:48px}
.f-success.show{display:block}
.f-success i{font-size:56px;color:var(--accent);margin-bottom:18px}
.f-success h3{font-size:22px;color:var(--primary);margin-bottom:10px}
.f-success p{color:var(--g400)}

/* ===== FOOTER ===== */
.footer{background:var(--primary-d);padding:72px 0 0;color:rgba(255,255,255,.55)}
.ft-main{display:grid;grid-template-columns:380px 1fr;gap:64px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-logo-img{height:48px;margin-bottom:20px;opacity:.95}
.ft-slogan{font-size:13.5px;color:var(--accent);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
.ft-desc{font-size:15px;color:rgba(255,255,255,.45);line-height:1.65;margin-bottom:20px}
.ft-badges{display:flex;gap:16px;flex-wrap:wrap}
.ft-badges span{font-size:12px;color:rgba(255,255,255,.35);display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(255,255,255,.04);border-radius:6px;border:1px solid rgba(255,255,255,.06)}
.ft-badges i{color:var(--accent);font-size:12px}
.ft-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.ft-col h4{font-size:15px;font-weight:800;color:var(--white);margin-bottom:20px}
.ft-col li{margin-bottom:10px;font-size:14.5px;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:8px}
.ft-col a{color:rgba(255,255,255,.45);display:flex;align-items:center;gap:8px}
.ft-col a:hover{color:var(--accent)}
.ft-col i{font-size:11px;color:var(--accent);width:14px;flex-shrink:0}
.indent{padding-left:22px}
.ft-bottom{padding:24px 0;text-align:center}
.ft-bottom p{font-size:13px;color:rgba(255,255,255,.25)}

/* ===== BACK TO TOP ===== */
.btt{position:fixed;bottom:32px;right:32px;width:48px;height:48px;background:var(--primary);color:var(--white);border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(16px);transition:var(--tr);box-shadow:var(--sh-l);z-index:999}
.btt.vis{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover{background:var(--accent);transform:translateY(-4px)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .ccu-inner{padding:80px 0 64px}
  .ccu-slogan{font-size:clamp(24px,3vw,34px)}
  .ccu-co-layout{grid-template-columns:1fr;gap:28px}
  .ccu-seal{position:static;display:flex;justify-content:center}
  .ccu-cards{grid-template-columns:repeat(2,1fr);gap:14px}
  .ccu-card--wide{grid-column:span 2}
  .ccu-card--full{grid-column:1/-1}
  .vision-cards{grid-template-columns:1fr;max-width:480px;margin:0 auto 64px}
  .about-intro-grid{grid-template-columns:1fr}
  .about-ci-colors{grid-template-columns:repeat(2,1fr)}
  .ci-logo-main{grid-template-columns:1fr 1fr 1fr}
  .ci-symbol-meaning{grid-template-columns:1fr}
  .ci-v2{padding:80px 0}
  .ci-v2-logo-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .ci-v2-meaning-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .ci-v2-mean-card--info{grid-column:1/-1}
  .org-v3-depts{grid-template-columns:repeat(2,1fr)}
  .org-v3-connector{display:none}
  .biz-panel{grid-template-columns:1fr}
  .bp-img{min-height:240px}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .port-stats{grid-template-columns:repeat(2,1fr)}
  .pt-th-field{width:180px}
  .pt-table td{padding:12px 16px;font-size:14px}
  .pt-table th{padding:14px 16px;font-size:12px}
  .ft-main{grid-template-columns:1fr}
  .process-flow{flex-wrap:wrap;gap:8px}
  .pf-step{min-width:140px;flex:none;width:calc(33% - 12px)}
  .pf-arrow{display:none}
  .htv2-line{left:24px}
  .htv2-item{padding-right:0;padding-left:56px}
  .htv2-item.htv2-right{padding-left:56px;flex-direction:row;text-align:left}
  .htv2-year{left:24px;transform:translateX(-50%)}
  .htv2-dot{left:24px;transform:translateX(-50%)}
  .htv2-card{text-align:left!important}
}

@media(max-width:768px){
  :root{--sec-py:80px}
  .mob-btn{display:flex}
  .nav-links{display:none!important}
  .header-inner{height:72px}
  .logo-img{height:40px}
  .hero{min-height:100svh}
  .hero-bg{background-attachment:scroll}
  .vision-bg{background-attachment:scroll}
  .biz-hero-bg{background-attachment:scroll}
  .about-hero-bg{background-attachment:scroll}
  .about-ci-bg{background-attachment:scroll}
  .about-hist-bg{background-attachment:scroll}
  .about-photo-break--1{height:200px}
  .about-photo-break--2{height:180px}
  .about-hero{height:300px}
  .about-intro{padding:48px 0}
  .ccu-inner{padding:56px 0 48px}
  .ccu-slogan{font-size:clamp(22px,5vw,28px)}
  .ccu-tabs{gap:6px}
  .ccu-tab{padding:8px 16px;font-size:12px}
  .ccu-tab-content p{font-size:17px}
  .ccu-name-info{font-size:14px}
  .ccu-name-info strong{font-size:16px}
  .ccu-divider{margin:40px auto 36px}
  .ccu-cards{grid-template-columns:1fr;gap:12px}
  .ccu-card--wide,.ccu-card--full{grid-column:auto}
  .ccu-card-content{padding:24px 20px}
  .ccu-card--featured .ccu-card-content{padding:28px 22px}
  .ccu-card-content--row{flex-wrap:wrap}
  .ccu-map-btn{width:100%;justify-content:center;margin-top:8px}
  .ccu-seal-ring{width:100px;height:100px}
  .about-ci{padding:60px 0}
  .about-org-wrap{padding:48px 0}
  .about-history-wrap{padding:60px 0}
  .hero-content{padding-top:72px}
  .hero-actions{flex-direction:column;max-width:300px}
  .hero-actions .btn{justify-content:center}
  .hero-stats{gap:32px;flex-wrap:wrap}
  .scroll-hint{display:none}
  .vision-sec{min-height:auto;padding:80px 0}
  .vision-cards{max-width:100%}
  .vision-card{min-height:280px}
  .vision-keywords{padding:20px 24px;gap:10px}
  .vk-item{font-size:13.5px}
  .vk-divider{display:none}
  .biz-hero{height:240px}
  .biz-tabs{margin:-24px 16px 32px;padding:12px;gap:6px}
  .biz-tab{padding:10px 16px;font-size:13px}
  .biz-tab i{display:none}
  .bp-detail{padding:28px}
  .port-grid{grid-template-columns:1fr}
  .port-stats{grid-template-columns:repeat(2,1fr);gap:12px}
  .pt-wrap{border-radius:var(--r);overflow-x:auto;-webkit-overflow-scrolling:touch}
  .pt-table{min-width:640px}
  .pt-filters{gap:8px}
  .pt-filter{padding:8px 20px;font-size:13px}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .form-card{padding:28px}
  .fg-row{grid-template-columns:1fr}
  .process-section{padding:28px 20px}
  .pf-step{width:100%;max-width:200px}
  .process-flow{flex-direction:column;align-items:center}
  .org-v3-depts{grid-template-columns:1fr 1fr;gap:12px}
  .org-v3-connector{display:none}
  .org-v3-dept{padding:24px 18px}
  .about-org-wrap{padding:60px 0}
  .org-bg-img{background-attachment:scroll}
  .about-ceo-inner{padding:28px 28px 28px 36px}
  .about-company-info{padding:28px}
  .about-ci-colors{grid-template-columns:1fr 1fr;gap:12px}
  .ci-logo-main{grid-template-columns:1fr}
  .ci-symbol-meaning{grid-template-columns:1fr;gap:16px}
  .ci-meaning-card{flex-direction:column;text-align:center;align-items:center}
  .ci-font-box{flex-direction:column;text-align:center;gap:12px}
  .ci-v2{padding:60px 0}
  .ci-v2-logo-grid{grid-template-columns:1fr;gap:16px;max-width:400px;margin:0 auto}
  .ci-v2-meaning-grid{grid-template-columns:1fr;gap:16px}
  .ci-v2-mean-card--info{grid-column:auto}
  .ci-v2-logo-img-wrap{padding:32px 24px;min-height:120px}
  .ci-v2-slogan{font-size:18px}
  .ft-links{grid-template-columns:1fr;gap:24px}
}

@media(max-width:480px){
  .ccu-inner{padding:40px 0 36px}
  .ccu-badge{margin-bottom:24px}
  .ccu-slogan{font-size:22px}
  .ccu-name-bar{gap:12px;margin-bottom:28px}
  .ccu-name-line{max-width:40px}
  .ccu-name-info{font-size:13px}
  .ccu-name-info strong{font-size:15px}
  .ccu-tabs{flex-direction:column}
  .ccu-tab{justify-content:center;width:100%}
  .ccu-tab-content p{font-size:16px;line-height:1.9}
  .org-v3-depts{grid-template-columns:1fr}
  .org-v3-ceo-card{padding:16px 28px}
  .about-info-items{grid-template-columns:1fr}
  .about-ci-colors{grid-template-columns:1fr 1fr}
  .port-stats{grid-template-columns:1fr 1fr}
  .pt-filter{padding:8px 16px;font-size:12px}
  .pt-count{font-size:11px;padding:1px 6px}
}

@media print{
  .header,.scroll-hint,.btt,.mob-btn,.nav-mob{display:none!important}
  .hero{min-height:auto;padding:40px 0}
}