/*
 * Theme Name:  Chandra Surya Portal
 * Theme URI:   https://www.hamrocsjn.com
 * Description: Multi-page portal for Chandra Surya 株式会社 — Housing, SIM, Career & Visa, Life Planning.
 * Version:     2.0.0
 * Author:      Chandra Surya 株式会社
 * Text Domain: chandra-surya
 */

/* =========================================================================
   TOKENS
   ========================================================================= */
:root{
  --red:#C8102E;--red-d:#9B0E23;--red-l:#E8405A;
  --blue:#003087;--blue-m:#1A4DB5;--blue-l:#2563EB;
  --white:#fff;--off:#F7F8FC;--g100:#F0F2F8;--g200:#DDE1EF;--g500:#6B7280;--g800:#1E2340;
  --text:#111827;--muted:#4B5563;
  --gh:linear-gradient(135deg,#003087 0%,#1A4DB5 50%,#C8102E 100%);
  --gr:linear-gradient(135deg,#9B0E23,#E8405A);
  --gb:linear-gradient(135deg,#003087,#2563EB);
  --sh-sm:0 2px 8px rgba(0,0,0,.07);
  --sh-md:0 6px 24px rgba(0,0,0,.10);
  --sh-lg:0 16px 48px rgba(0,0,0,.14);
  --sh-b:0 8px 32px rgba(0,48,135,.22);
  --sh-r:0 8px 32px rgba(200,16,46,.22);
  --r-sm:6px;--r-md:12px;--r-lg:20px;--r-xl:32px;--r-p:999px;
  --nav:76px;--mw:1320px;
  --fs-xs:clamp(.75rem,1.1vw,.85rem);
  --fs-sm:clamp(.875rem,1.3vw,1rem);
  --fs-b:clamp(1rem,1.5vw,1.125rem);
  --fs-md:clamp(1.125rem,1.8vw,1.375rem);
  --fs-lg:clamp(1.5rem,2.5vw,2rem);
  --fs-xl:clamp(2rem,3.5vw,3rem);
  --fs-2xl:clamp(2.5rem,5vw,4rem);
  --sp-xs:clamp(.5rem,1vw,.75rem);
  --sp-sm:clamp(.75rem,1.5vw,1rem);
  --sp-md:clamp(1rem,2vw,1.5rem);
  --sp-lg:clamp(1.5rem,3vw,2.5rem);
  --sp-xl:clamp(2.5rem,5vw,4rem);
  --sp-2xl:clamp(4rem,8vw,7rem);
  --ease:cubic-bezier(.22,1,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

/* =========================================================================
   RESET
   ========================================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Noto Sans JP','DM Sans',system-ui,sans-serif;font-size:var(--fs-b);color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.65}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}
h1,h2,h3,h4,h5{font-family:'Playfair Display','Noto Serif JP',serif;line-height:1.2;letter-spacing:-.02em}

/* =========================================================================
   LAYOUT
   ========================================================================= */
.wrap{width:100%;max-width:var(--mw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.section{padding-block:var(--sp-2xl)}
.section--alt{background:var(--off)}
.section--dark{background:var(--g800);color:var(--white)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-lg)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-md)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-md)}
.sec-head{text-align:center;margin-bottom:var(--sp-xl)}
.sec-head h2{font-size:var(--fs-xl);margin-bottom:var(--sp-sm)}
.sec-head p{color:var(--muted);font-size:var(--fs-md);max-width:600px;margin-inline:auto}
.eyebrow{display:inline-block;font-size:var(--fs-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:var(--sp-sm)}
.eyebrow--w{color:rgba(255,255,255,.75)}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;border-radius:var(--r-p);font-size:var(--fs-sm);font-weight:700;transition:transform 320ms var(--ease),box-shadow 320ms var(--ease),background 180ms;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn--red{background:var(--red);color:#fff;box-shadow:var(--sh-r)}
.btn--red:hover{background:var(--red-d)}
.btn--blue{background:var(--blue);color:#fff;box-shadow:var(--sh-b)}
.btn--blue:hover{background:var(--blue-m)}
.btn--white{background:#fff;color:var(--blue);box-shadow:var(--sh-md)}
.btn--outline{background:transparent;border:2px solid rgba(255,255,255,.5);color:#fff}
.btn--outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn--ghost{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn--ghost:hover{background:var(--blue);color:#fff}
.btn--sm{padding:.5rem 1.25rem;font-size:var(--fs-xs)}

/* =========================================================================
   NAVIGATION
   ========================================================================= */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav);transition:background 320ms var(--ease),box-shadow 320ms}
.site-header.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(0,0,0,.08),var(--sh-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav);max-width:var(--mw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.nav-logo{display:flex;align-items:center;gap:.75rem;font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--white);transition:color 180ms}
.site-header.scrolled .nav-logo{color:var(--blue)}
.nav-logo__img{width:auto;max-width:200px;height:44px;border-radius:var(--r-sm);object-fit:contain;background:#fff;padding:4px;flex-shrink:0}
.nav-logo__lines{display:flex;flex-direction:column;line-height:1.1}
.nav-logo__lines small{font-size:.62rem;font-family:'Noto Sans JP',sans-serif;font-weight:400;color:rgba(255,255,255,.65);letter-spacing:.04em}
.site-header.scrolled .nav-logo__lines small{color:var(--g500)}

.nav-links{display:flex;align-items:center;gap:var(--sp-md)}
.nav-links > a,.nav-dd__btn{font-size:var(--fs-xs);font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.02em;transition:color 180ms;position:relative;padding-bottom:2px;background:none;display:inline-flex;align-items:center;gap:.25rem}
.site-header.scrolled .nav-links > a,
.site-header.scrolled .nav-dd__btn{color:var(--muted)}
.nav-links > a:hover,.nav-dd__btn:hover,
.nav-links > a.active{color:#fff}
.site-header.scrolled .nav-links > a:hover,
.site-header.scrolled .nav-dd__btn:hover,
.site-header.scrolled .nav-links > a.active{color:var(--blue)}
.nav-links > a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red-l);border-radius:2px;transform:scaleX(0);transition:transform 320ms var(--ease)}
.nav-links > a:hover::after,.nav-links > a.active::after{transform:scaleX(1)}

/* Dropdown */
.nav-dd{position:relative}
.nav-dd__btn svg{width:11px;height:11px;transition:transform 180ms}
.nav-dd:hover .nav-dd__btn svg{transform:rotate(180deg)}
.nav-dd__panel{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px);background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-lg);min-width:230px;padding:.5rem;opacity:0;pointer-events:none;transition:opacity 280ms var(--ease),transform 280ms var(--ease);border:1px solid var(--g200);z-index:10}
.nav-dd:hover .nav-dd__panel{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dd__panel a{display:flex;align-items:center;gap:.65rem;padding:.65rem .9rem;border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:600;color:var(--text);transition:background 150ms,color 150ms}
.nav-dd__panel a:hover{background:var(--g100);color:var(--blue)}
.nav-dd__icon{width:26px;height:26px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.85rem}

.nav-cta{padding:.55rem 1.25rem;background:var(--red);color:#fff;border-radius:var(--r-p);font-size:var(--fs-xs);font-weight:700;transition:background 180ms,transform 180ms var(--spring)}
.nav-cta:hover{background:var(--red-d);transform:translateY(-1px)}

.nav-toggle{display:none;flex-direction:column;gap:5px;width:30px;padding:4px;cursor:pointer}
.nav-toggle span{display:block;height:2px;background:#fff;border-radius:2px;transition:transform 320ms var(--ease),opacity 180ms}
.site-header.scrolled .nav-toggle span{background:var(--g800)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{display:none;position:fixed;inset:0;background:var(--blue);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:2rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.5rem;color:#fff;font-family:'Playfair Display',serif;font-weight:700;transition:color 150ms}
.mobile-nav a:hover{color:var(--red-l)}
.mobile-nav__close{position:absolute;top:1.5rem;right:1.5rem;font-size:2.5rem;color:#fff;cursor:pointer;line-height:1}

/* =========================================================================
   HERO CAROUSEL
   ========================================================================= */
.hero-carousel{position:relative;height:100svh;min-height:640px;overflow:hidden;background:#000}
.hero-slides{display:flex;height:100%;width:100%}
.hero-slide{flex:1;height:100%;position:relative;display:flex;align-items:center;transition:flex 0.8s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.8s;cursor:pointer;overflow:hidden;padding-top:var(--nav)}
.hero-slide.active{flex:7;cursor:default}
.hero-slide__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 0.8s, filter 0.8s;transform:scale(1.1);filter:brightness(0.6)}
.hero-slide.active .hero-slide__bg{transform:scale(1);filter:brightness(1)}

/* Gradient overlays per slide */
.hero-slide:nth-child(1) .hero-slide__bg{background-image:linear-gradient(135deg,#003087 0%,#1A4DB5 100%)}
.hero-slide:nth-child(2) .hero-slide__bg{background-image:linear-gradient(135deg,#0f3460 0%,#16213e 100%)}
.hero-slide:nth-child(3) .hero-slide__bg{background-image:linear-gradient(135deg,#1a0a00 0%,#5c1212 50%,#C8102E 100%)}
.hero-slide:nth-child(4) .hero-slide__bg{background-image:linear-gradient(135deg,#0a1628 0%,#003087 50%,#1A4DB5 100%)}

.hero-slide__overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.65) 0%,transparent 70%);opacity:0;transition:opacity 0.8s}
.hero-slide.active .hero-slide__overlay{opacity:1}

.hero-slide__deco{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-slide__deco::before{content:'';position:absolute;right:-5%;top:10%;width:55%;height:80%;border-radius:50%;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);opacity:0;transition:opacity 0.8s}
.hero-slide.active .hero-slide__deco::before{opacity:1}
.hero-slide__deco::after{content:'';position:absolute;right:15%;bottom:-10%;width:35%;height:60%;border-radius:50%;background:rgba(255,255,255,.02);opacity:0;transition:opacity 0.8s}
.hero-slide.active .hero-slide__deco::after{opacity:1}

/* Active Slide Content */
.hero-content{position:relative;z-index:1;padding-inline:clamp(1rem,3vw,1rem);max-width:700px;opacity:0;visibility:hidden;transform:translateX(-30px);transition:all 0.5s ease;width:100%}
.hero-slide.active .hero-content{opacity:1;visibility:visible;transform:translateX(0);transition-delay:0.3s;transition-duration:0.8s}

.hero-tag{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);border-radius:var(--r-p);padding:.3rem .9rem;font-size:var(--fs-xs);color:#fff;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--sp-md)}
.hero-tag span{width:8px;height:8px;border-radius:50%;background:currentColor}
.hero-title{font-size:clamp(1.8rem,4vw,3.5rem);color:#fff;margin-bottom:var(--sp-md);line-height:1.1;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero-title em{font-style:normal;color:var(--red-l)}
.hero-desc{font-size:var(--fs-md);color:rgba(255,255,255,.85);margin-bottom:var(--sp-lg);max-width:540px;line-height:1.75}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--sp-sm)}

/* Inactive Slide Title */
.vert-title{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;opacity:1;transition:opacity 0.3s;z-index:2;gap:1.5rem}
.hero-slide.active .vert-title{opacity:0;pointer-events:none}
.vert-title span{writing-mode:vertical-rl;transform:rotate(180deg);font-size:clamp(1rem,1.5vw,1.25rem);font-weight:700;letter-spacing:0.1em;white-space:nowrap;font-family:'Playfair Display',serif;text-shadow:0 2px 5px rgba(0,0,0,.5)}
.vert-icon{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.3)}
.vert-icon svg{width:20px;height:20px;stroke:#fff}

/* =========================================================================
   PROPERTY CARDS & HOUSING
   ========================================================================= */
.prop-filters{background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:var(--sp-lg);margin-bottom:var(--sp-xl);border:1px solid var(--g200)}
.filter-tabs{display:flex;gap:0;border-bottom:2px solid var(--g200);margin-bottom:var(--sp-lg)}
.f-tab{padding:.7rem 1.5rem;font-size:var(--fs-sm);font-weight:700;color:var(--g500);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color 150ms,border-color 150ms}
.f-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.filter-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:var(--sp-sm);align-items:end}

.f-label{display:block;font-size:var(--fs-xs);font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}
.f-input{width:100%;padding:.75rem 1rem;border:2px solid var(--g200);border-radius:var(--r-md);font-size:var(--fs-sm);color:var(--text);background:var(--off);outline:none;transition:border-color 150ms,box-shadow 150ms;-webkit-appearance:none}
.f-input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,48,135,.08);background:#fff}
.f-sel{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}

.prop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:var(--sp-md)}
.prop-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);overflow:hidden;cursor:pointer;transition:transform 320ms var(--ease),box-shadow 320ms}
.prop-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.prop-img{position:relative;overflow:hidden;aspect-ratio:4/3}
.prop-img img,.prop-img-ph{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.prop-img-ph{display:flex;align-items:center;justify-content:center;font-size:3rem;background:var(--g100)}
.prop-card:hover .prop-img img{transform:scale(1.07)}
.prop-badge{position:absolute;top:.75rem;left:.75rem;background:var(--blue);color:#fff;padding:.2rem .65rem;border-radius:var(--r-p);font-size:.68rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.prop-badge--sell{background:var(--red)}
.prop-badge--rent{background:var(--blue)}
.prop-badge--buy{background:#16a34a}
.prop-badge--new{background:#d97706}
.prop-fav{position:absolute;top:.75rem;right:.75rem;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform 180ms var(--spring)}
.prop-fav:hover{transform:scale(1.2)}
.prop-fav svg{width:15px;height:15px;stroke:var(--red);fill:none;transition:fill 150ms}
.prop-fav.liked svg{fill:var(--red)}
.prop-body{padding:var(--sp-md)}
.prop-type{display:inline-block;font-size:var(--fs-xs);font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .65rem;border-radius:var(--r-p);margin-bottom:var(--sp-xs)}
.prop-type--sell{background:rgba(200,16,46,.1);color:var(--red)}
.prop-type--rent{background:rgba(0,48,135,.1);color:var(--blue)}
.prop-type--buy{background:rgba(22,163,74,.1);color:#16a34a}
.prop-title{font-size:var(--fs-sm);font-weight:700;margin-bottom:.3rem;font-family:'Noto Sans JP',sans-serif;color:var(--text)}
.prop-loc{font-size:var(--fs-xs);color:var(--g500);margin-bottom:var(--sp-xs)}
.prop-price{font-size:var(--fs-lg);font-weight:900;color:var(--blue);font-family:'Playfair Display',serif}
.prop-price span{font-size:var(--fs-xs);font-weight:400;color:var(--g500)}
.prop-stats{display:flex;gap:.75rem;margin-top:var(--sp-xs);flex-wrap:wrap}
.prop-stat{font-size:var(--fs-xs);color:var(--g500);display:flex;align-items:center;gap:.3rem}
.prop-stat svg{width:13px;height:13px;stroke:var(--g500);fill:none;stroke-width:1.8}

/* =========================================================================
   SIM PLANS
   ========================================================================= */
.sim-page-hero{background:var(--gb);padding-top:calc(var(--nav) + var(--sp-2xl));padding-bottom:var(--sp-2xl);position:relative;overflow:hidden;color:#fff}
.sim-page-hero::after{content:'5G';position:absolute;right:-1rem;top:50%;transform:translateY(-50%);font-size:clamp(8rem,20vw,18rem);font-weight:900;color:rgba(255,255,255,.04);line-height:1;font-family:'Playfair Display',serif;pointer-events:none}

.carrier-bar{display:flex;gap:var(--sp-sm);overflow-x:auto;padding-bottom:.5rem;margin-bottom:var(--sp-xl);scrollbar-width:none}
.carrier-bar::-webkit-scrollbar{display:none}
.c-tab{flex-shrink:0;padding:.7rem 1.5rem;border-radius:var(--r-p);background:var(--g100);border:2px solid var(--g200);font-size:var(--fs-sm);font-weight:700;color:var(--g500);cursor:pointer;transition:background 150ms,color 150ms,border-color 150ms}
.c-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}

.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:var(--sp-md)}
.plan-card{background:#fff;border-radius:var(--r-xl);border:2px solid var(--g200);padding:var(--sp-lg);text-align:center;position:relative;overflow:hidden;transition:transform 320ms var(--ease),box-shadow 320ms,border-color 150ms}
.plan-card:hover{transform:translateY(-8px);box-shadow:var(--sh-b);border-color:var(--blue)}
.plan-card--hot{border-color:var(--blue);background:linear-gradient(180deg,rgba(0,48,135,.04) 0%,#fff 100%)}
.plan-card--hot::before{content:'Most Popular';position:absolute;top:14px;right:-28px;background:var(--red);color:#fff;font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.3rem 3rem;transform:rotate(45deg)}
.plan-carrier{font-size:var(--fs-sm);font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}
.plan-price{font-size:var(--fs-2xl);font-weight:900;color:var(--blue);font-family:'Playfair Display',serif;margin:.75rem 0 .25rem}
.plan-price span{font-size:var(--fs-sm);font-weight:400;color:var(--g500)}
.plan-data{font-size:var(--fs-md);font-weight:800;color:var(--g800);margin-bottom:var(--sp-sm)}
.plan-feats{text-align:left;margin:var(--sp-md) 0}
.plan-feats li{display:flex;align-items:center;gap:.5rem;font-size:var(--fs-xs);padding:.4rem 0;border-bottom:1px solid var(--g100)}
.plan-feats li::before{content:'✓';color:#16a34a;font-weight:800;flex-shrink:0}

.compare-wrap{overflow-x:auto;border-radius:var(--r-lg);box-shadow:var(--sh-sm);border:1px solid var(--g200)}
.compare-tbl{width:100%;border-collapse:collapse;min-width:600px}
.compare-tbl th,.compare-tbl td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--g200);font-size:var(--fs-sm)}
.compare-tbl thead th{background:var(--g800);color:#fff;font-weight:700}
.compare-tbl thead th:first-child{border-radius:var(--r-md) 0 0 0}
.compare-tbl thead th:last-child{border-radius:0 var(--r-md) 0 0}
.compare-tbl tr:nth-child(even) td{background:var(--g100)}
.compare-tbl td:first-child{font-weight:600;color:var(--text)}
.ck{color:#16a34a;font-size:1.1rem}
.cx{color:var(--red);font-size:1.1rem}

/* =========================================================================
   CAREER & VISA
   ========================================================================= */
.career-hero{background:var(--gh);padding-top:calc(var(--nav) + var(--sp-2xl));padding-bottom:var(--sp-2xl);color:#fff}

.steps-row{display:flex;gap:0;position:relative;margin:var(--sp-xl) 0}
.steps-row::before{content:'';position:absolute;top:28px;left:0;right:0;height:2px;background:var(--g200);z-index:0}
.step-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-sm);padding:var(--sp-sm);position:relative;z-index:1}
.step-n{width:56px;height:56px;border-radius:50%;background:#fff;border:3px solid var(--g200);display:flex;align-items:center;justify-content:center;font-size:var(--fs-md);font-weight:900;color:var(--g500);transition:border-color 320ms,color 320ms,background 320ms}
.step-item.done .step-n{background:var(--blue);border-color:var(--blue);color:#fff}
.step-item.current .step-n{background:var(--red);border-color:var(--red);color:#fff;box-shadow:var(--sh-r)}
.step-lbl{font-size:var(--fs-xs);font-weight:700;color:var(--muted)}

.college-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);padding:var(--sp-md);display:flex;gap:var(--sp-md);align-items:flex-start;transition:box-shadow 320ms,transform 320ms}
.college-card:hover{box-shadow:var(--sh-md);transform:translateX(4px)}
.college-logo{width:64px;height:64px;border-radius:var(--r-md);background:var(--g100);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:1.5rem}
.college-info h3{font-size:var(--fs-sm);margin-bottom:.2rem;font-family:'Noto Sans JP',sans-serif;font-weight:700}
.college-info p{font-size:var(--fs-xs);color:var(--muted);line-height:1.6}
.ctags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}
.ctag{font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.15rem .5rem;border-radius:var(--r-p);background:var(--g100);color:var(--g500)}

.visa-card{background:#fff;border-radius:var(--r-lg);padding:var(--sp-lg);border:2px solid var(--g200);transition:border-color 150ms,box-shadow 320ms,transform 320ms}
.visa-card:hover{border-color:var(--blue);box-shadow:var(--sh-b);transform:translateY(-4px)}
.visa-icon{width:52px;height:52px;border-radius:var(--r-md);background:rgba(0,48,135,.08);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-md)}
.visa-icon svg{width:26px;height:26px;stroke:var(--blue);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* =========================================================================
   LONG-TERM LIFE PLANNING
   ========================================================================= */
.life-hero{background:linear-gradient(135deg,#0a1628 0%,#003087 60%,#1A4DB5 100%);padding-top:calc(var(--nav) + var(--sp-2xl));padding-bottom:var(--sp-2xl);color:#fff;position:relative;overflow:hidden}
.life-hero::before{content:'';position:absolute;top:-20%;right:-10%;width:60%;height:130%;border-radius:50%;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}

.timeline{position:relative;padding-left:3rem}
.timeline::before{content:'';position:absolute;left:1.2rem;top:0;bottom:0;width:3px;background:var(--gh);border-radius:3px}
.tl-item{position:relative;padding-bottom:var(--sp-xl)}
.tl-dot{position:absolute;left:-2.3rem;top:.3rem;width:22px;height:22px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 2px var(--blue);background:var(--blue)}
.tl-item:nth-child(even) .tl-dot{background:var(--red);box-shadow:0 0 0 2px var(--red)}
.tl-year{display:inline-block;font-size:var(--fs-xs);font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);background:rgba(0,48,135,.06);padding:.2rem .75rem;border-radius:var(--r-p);margin-bottom:var(--sp-sm)}
.tl-card{background:#fff;border-radius:var(--r-lg);padding:var(--sp-lg);box-shadow:var(--sh-sm);border:1px solid var(--g200);transition:box-shadow 320ms}
.tl-card:hover{box-shadow:var(--sh-md)}
.tl-card h3{font-size:var(--fs-md);margin-bottom:var(--sp-sm);font-family:'Noto Sans JP',sans-serif;font-weight:700}
.tl-card p{font-size:var(--fs-sm);color:var(--muted);line-height:1.75}

.invest-card{background:var(--gb);border-radius:var(--r-xl);padding:var(--sp-xl);color:#fff}
.invest-label{font-size:var(--fs-xs);font-weight:700;opacity:.7;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.4rem;display:block}
.invest-input{width:100%;padding:.75rem 1rem;border-radius:var(--r-md);background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:var(--fs-sm);outline:none;margin-bottom:var(--sp-md)}
.invest-result{background:rgba(255,255,255,.1);border-radius:var(--r-lg);padding:var(--sp-lg);text-align:center;margin-top:var(--sp-md)}
.invest-num{font-size:var(--fs-2xl);font-weight:900;font-family:'Playfair Display',serif}
.invest-desc{font-size:var(--fs-xs);opacity:.7;margin-top:.25rem}

/* =========================================================================
   ABOUT PAGE
   ========================================================================= */
.about-hero{background:var(--gh);padding-top:calc(var(--nav) + var(--sp-xl));padding-bottom:0;color:#fff;position:relative}
.about-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-radius:var(--r-xl) var(--r-xl) 0 0;overflow:hidden;box-shadow:var(--sh-lg)}
.a-stat{padding:var(--sp-lg);text-align:center;border-right:1px solid var(--g200)}
.a-stat:last-child{border-right:none}
.a-stat__n{font-size:var(--fs-2xl);font-weight:900;color:var(--blue);font-family:'Playfair Display',serif}
.a-stat__l{font-size:var(--fs-xs);color:var(--g500);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}
.team-card{text-align:center;background:#fff;border-radius:var(--r-lg);padding:var(--sp-lg);border:1px solid var(--g200);transition:transform 320ms var(--ease),box-shadow 320ms}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.team-av{width:80px;height:80px;border-radius:50%;margin:0 auto var(--sp-md);background:var(--gh);display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;font-weight:900;font-family:'Playfair Display',serif}
.team-card h3{font-size:var(--fs-sm);margin-bottom:.2rem;font-family:'Noto Sans JP',sans-serif;font-weight:700}
.team-card p{font-size:var(--fs-xs);color:var(--g500)}

/* =========================================================================
   CONTACT & INQUIRY
   ========================================================================= */
.page-hero{background:var(--gh);padding-top:calc(var(--nav) + var(--sp-xl));padding-bottom:var(--sp-2xl);text-align:center;color:#fff}
.page-hero h1{font-size:var(--fs-xl);margin-bottom:var(--sp-sm)}
.page-hero p{font-size:var(--fs-md);opacity:.85;max-width:560px;margin-inline:auto}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:var(--sp-2xl);align-items:start}
.contact-sticky{position:sticky;top:calc(var(--nav) + 2rem)}
.c-method{display:flex;gap:1rem;align-items:flex-start;padding:var(--sp-md);background:#fff;border-radius:var(--r-lg);border:1px solid var(--g200);box-shadow:var(--sh-sm);margin-bottom:var(--sp-sm);transition:box-shadow 320ms}
.c-method:hover{box-shadow:var(--sh-md)}
.c-method__ico{width:48px;height:48px;border-radius:var(--r-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem}
.c-method__ico--r{background:rgba(200,16,46,.1)}
.c-method__ico--b{background:rgba(0,48,135,.1)}
.c-method__ico--g{background:rgba(6,199,85,.1)}
.c-method h4{font-size:var(--fs-sm);margin-bottom:.2rem;font-family:'Noto Sans JP',sans-serif;font-weight:700}
.c-method p{font-size:var(--fs-xs);color:var(--muted);line-height:1.6}
.socials{display:flex;gap:var(--sp-sm);margin-top:var(--sp-lg);flex-wrap:wrap}
.soc{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:#fff;transition:transform 180ms var(--spring)}
.soc:hover{transform:translateY(-3px)}
.soc--fb{background:#1877F2}.soc--ln{background:#06C755}.soc--vi{background:#7360F2}.soc--wa{background:#25D366}

.iq-form{background:#fff;border-radius:var(--r-xl);padding:var(--sp-xl);box-shadow:var(--sh-lg);border:1px solid var(--g200)}
.fg{margin-bottom:var(--sp-md)}
.fg label{display:block;font-size:var(--fs-xs);font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem}
.fg label .req{color:var(--red)}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md)}
.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.chk-lbl{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.55rem .75rem;border-radius:var(--r-md);border:2px solid var(--g200);font-size:var(--fs-xs);font-weight:600;transition:border-color 150ms,background 150ms}
.chk-lbl input[type=checkbox]{display:none}
.chk-lbl:has(input:checked){border-color:var(--blue);background:rgba(0,48,135,.04);color:var(--blue)}
.chk-box{width:16px;height:16px;border:2px solid var(--g200);border-radius:3px;flex-shrink:0;display:grid;place-items:center;transition:all 150ms}
.chk-lbl:has(input:checked) .chk-box{background:var(--blue);border-color:var(--blue)}
.chk-box-i{width:9px;height:9px;color:#fff;opacity:0;transform:scale(.4);transition:all 180ms var(--spring)}
.chk-lbl:has(input:checked) .chk-box-i{opacity:1;transform:scale(1)}
#form-response{display:none;margin-top:var(--sp-md);padding:var(--sp-sm) var(--sp-md);border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:600}
#form-response.ok{display:block;background:rgba(22,163,74,.08);color:#15803d;border:1px solid rgba(22,163,74,.25)}
#form-response.err{display:block;background:rgba(200,16,46,.08);color:var(--red);border:1px solid rgba(200,16,46,.2)}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--g800);color:rgba(255,255,255,.6);padding-block:var(--sp-xl) var(--sp-lg)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-xl);margin-bottom:var(--sp-xl)}
.footer-brand .nav-logo{color:#fff;margin-bottom:var(--sp-sm)}
.footer-brand p{font-size:var(--fs-sm);line-height:1.85;max-width:280px}
.fc h4{font-family:'Noto Sans JP',sans-serif;font-size:var(--fs-xs);font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-md)}
.fc li+li{margin-top:.55rem}
.fc a{font-size:var(--fs-xs);transition:color 150ms}
.fc a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:var(--sp-md);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-sm)}
.footer-bottom p{font-size:var(--fs-xs)}
.footer-socials{display:flex;gap:.5rem}

/* =========================================================================
   REVEAL ANIMATION
   ========================================================================= */
[data-r]{opacity:0;transform:translateY(20px);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}
[data-r].on{opacity:1;transform:translateY(0)}
[data-rd="1"]{transition-delay:100ms}[data-rd="2"]{transition-delay:200ms}[data-rd="3"]{transition-delay:300ms}[data-rd="4"]{transition-delay:400ms}

/* =========================================================================
   LOADING SPINNER
   ========================================================================= */
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-left:.5rem}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .about-stats-bar{grid-template-columns:repeat(2,1fr)}
  .a-stat:nth-child(2){border-right:none}
  .carousel-strip{display:none}
  .c-arrow--r{right:1.5rem}
}
@media(max-width:900px){
  .filter-row{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .contact-sticky{position:static}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .fg-row,.chk-grid{grid-template-columns:1fr}
  .steps-row{flex-wrap:wrap}
  .steps-row::before{display:none}
  .footer-grid{grid-template-columns:1fr}
  .hero-title{font-size:clamp(1.8rem,7vw,2.8rem)}
  .filter-row{grid-template-columns:1fr}
  .about-stats-bar{grid-template-columns:repeat(2,1fr)}
  .hero-slides{flex-direction:column}
  .hero-slide{padding-top:0}
  .vert-title span{writing-mode:horizontal-tb;transform:rotate(0);margin-left:1rem}
  .vert-title{flex-direction:row;justify-content:flex-start;padding-left:1.5rem}
}
@media(max-width:480px){
  .plan-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
}
