
:root{
  --bg:#f4f6f8;
  --white:#ffffff;
  --text:#2b2b2b;
  --muted:#5b6776;
  --line:#dbe3ea;
  --blue:#1E4E79;
  --teal:#3BAFBF;
  --gold:#D4A537;
  --shadow:0 18px 42px rgba(18,39,58,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
body{
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1380px, calc(100% - 36px));margin:0 auto}
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:80;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(219,227,234,.88);
}
.header-inner{
  min-height:88px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:24px;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-logo{
  width:58px;height:58px;object-fit:contain;
  padding:6px;border-radius:18px;background:#fff;border:1px solid rgba(212,165,55,.28);
  box-shadow:0 12px 24px rgba(30,78,121,.08);
}
.brand-copy{min-width:0}
.brand-title{font-size:1.95rem;font-weight:800;letter-spacing:-.03em;color:var(--blue);line-height:1}
.brand-tagline{margin-top:4px;font-size:.78rem;line-height:1.5;letter-spacing:.12em;text-transform:uppercase;color:#6f7b89;word-break:break-word}
.main-nav{display:flex;flex-wrap:wrap;gap:24px;font-size:1rem;color:#516071}
.main-nav a:hover,.footer-links a:hover{color:var(--blue)}
.lang-switcher{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:22px;background:#fff;padding:10px 12px;
}
.lang-switcher label{font-size:.95rem;color:#516071;white-space:nowrap}
.lang-switcher select{
  border:1px solid var(--line);background:var(--bg);border-radius:14px;
  padding:10px 14px;font-size:.95rem;color:#334155;min-width:190px;
}
.section{padding:34px 0 76px}
.hero{padding-top:138px;background:linear-gradient(180deg,#ffffff 0%,#eef4f7 100%)}
.hero-grid,.two-col{
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);
  gap:34px;align-items:start;
}
.badge{
  display:inline-flex;max-width:100%;flex-wrap:wrap;gap:8px;align-items:center;
  padding:10px 16px;border-radius:999px;border:1px solid rgba(30,78,121,.12);
  background:rgba(30,78,121,.05);color:var(--blue);
  font-size:.9rem;line-height:1.6;letter-spacing:.12em;text-transform:uppercase;
}
.hero-copy h1{
  margin:22px 0 0;font-size:clamp(3rem,7vw,6rem);line-height:.96;letter-spacing:-.05em;
  color:var(--blue);font-weight:900;
}
.hero-copy h1 span{
  display:block;margin-top:12px;color:#0f172a;
  font-size:clamp(2.1rem,5.6vw,4.6rem);line-height:1.02;
}
.lead{margin:24px 0 0;max-width:900px;font-size:1.16rem;line-height:1.88;color:var(--muted)}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:56px;padding:0 22px;border-radius:18px;font-weight:700;transition:.2s ease;
}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 16px 32px rgba(30,78,121,.18)}
.btn-primary:hover{background:#163a59}
.btn-secondary{background:#fff;color:var(--blue);border:1px solid rgba(30,78,121,.18)}
.btn-secondary:hover{background:#f7fafc}
.btn-gold{background:var(--gold);color:#2b2b2b}
.btn-gold:hover{filter:brightness(.96)}
.hero-card,.panel,.card,.service-card, .metric-card{
  border-radius:30px;box-shadow:var(--shadow);
}
.hero-card{background:var(--blue);color:#fff;padding:30px}
.hero-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.hero-card-label,.panel-label,.section-label{
  font-size:.84rem;line-height:1.5;letter-spacing:.18em;text-transform:uppercase
}
.hero-card-label,.panel-label{opacity:.86}
.section-label{color:var(--teal);font-weight:700}
.hero-card-logo{
  width:66px;height:66px;object-fit:contain;padding:6px;border-radius:18px;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12)
}
.hero-card h2,.panel h2{margin:14px 0 0;font-size:clamp(1.8rem,3vw,2.5rem);line-height:1.08;letter-spacing:-.03em}
.hero-card p,.panel-dark p{margin:18px 0 0;line-height:1.85;color:rgba(255,255,255,.88)}
.hero-list{margin-top:20px;display:grid;gap:12px}
.hero-list-item{
  display:flex;gap:10px;align-items:flex-start;
  background:rgba(255,255,255,.10);padding:12px 14px;border-radius:18px
}
.hero-list-item .check{color:var(--gold);font-weight:900}
.metric-grid,.card-grid,.operating-grid,.search-grid,.faq-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;
}
.metric-card{
  background:rgba(255,255,255,.86);
  border:1px solid var(--line);
  padding:18px 20px;
}
.metric-card .metric-value{font-size:1.06rem;font-weight:800;color:var(--blue)}
.metric-card .metric-label{margin-top:4px;font-size:.92rem;color:#6f7b89}
.card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.card{
  background:#fff;border:1px solid var(--line);padding:24px;
}
.card h3{margin:0 0 10px;color:var(--blue);font-size:1.28rem}
.card p{margin:0;color:var(--muted);line-height:1.85}
.operating-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:10px}
.operating-card{
  background:#fff;border:1px solid var(--line);padding:24px;border-radius:28px;box-shadow:var(--shadow);
}
.operating-icon{
  width:42px;height:42px;border-radius:14px;background:rgba(30,78,121,.08);
  display:grid;place-items:center;color:var(--blue);font-weight:800
}
.operating-card h3{margin:14px 0 0;color:var(--blue);font-size:1.16rem}
.operating-card p{margin:12px 0 0;color:var(--muted);line-height:1.8}
.white{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-head{padding-bottom:16px}
.section-head h2{margin:12px 0 0;color:var(--blue);font-size:clamp(2rem,4vw,3.6rem);line-height:1.08;letter-spacing:-.04em}
.section-head p{margin:18px 0 0;font-size:1.08rem;line-height:1.9;color:var(--muted);max-width:980px}
.service-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:24px;
}
.service-card{
  background:#fff;border:1px solid var(--line);padding:24px;
}
.service-card.featured{
  grid-column:span 2;
  background:var(--blue);color:#fff;border:0;
}
.service-card h3{margin:0;color:var(--blue);font-size:1.24rem}
.service-card.featured h3{color:#fff}
.service-card p{margin:12px 0 0;color:var(--muted);line-height:1.8}
.service-card.featured p{color:rgba(255,255,255,.88)}
.service-cta{margin-top:18px}
.panel{padding:30px}
.panel-dark{background:var(--blue);color:#fff;border:0}
.panel-light{background:#fff;border:1px solid var(--line)}
.panel-label-teal{color:var(--teal);opacity:1;font-weight:700}
.panel-light h2{color:var(--blue)}
.panel-light p{color:var(--muted)}
.contact-copy{margin-top:14px}
.contact-list{margin-top:22px;display:grid;gap:14px}
.contact-row{
  display:flex;align-items:center;gap:14px;
  border-radius:18px;background:#f4f6f8;padding:16px 18px;color:#1f2937;font-weight:600
}
.contact-icon{font-size:1.05rem}
.search-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:22px}
.search-item{
  display:flex;gap:12px;align-items:flex-start;background:#f4f6f8;border:1px solid var(--line);
  border-radius:20px;padding:14px 16px
}
.search-item .check{color:var(--teal);font-weight:900}
.faq-list{margin-top:26px;display:grid;gap:14px}
.faq-item{
  border:1px solid var(--line);border-radius:22px;background:#f4f6f8;padding:18px 20px;
}
.faq-item h3{margin:0;color:var(--blue);font-size:1.04rem}
.faq-item p{margin:12px 0 0;color:var(--muted);line-height:1.8}
.cta-band{
  border-radius:32px;background:linear-gradient(90deg,var(--blue),#225b8d,var(--teal));
  color:#fff;padding:30px;box-shadow:0 24px 44px rgba(30,78,121,.18)
}
.cta-band .eyebrow{
  font-size:.84rem;line-height:1.5;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.76)
}
.cta-band h2{
  margin:14px 0 0;font-size:clamp(2rem,3vw,3rem);line-height:1.12;letter-spacing:-.03em
}
.cta-band p{margin:16px 0 0;max-width:980px;line-height:1.9;color:rgba(255,255,255,.88)}
.cta-band .cta-row{margin-top:24px}
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer-inner{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 0;color:#6f7b89;font-size:.95rem
}
.footer-links{display:flex;flex-wrap:wrap;gap:18px}
@media (max-width:1180px){
  .header-inner{grid-template-columns:minmax(0,1fr);align-items:start}
  .main-nav{gap:18px}
  .hero{padding-top:180px}
  .metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:980px){
  .hero{padding-top:206px}
  .hero-grid,.two-col,.card-grid,.service-grid,.operating-grid{grid-template-columns:1fr 1fr}
  .service-card.featured{grid-column:span 1}
  .search-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .hero-grid,.two-col,.card-grid,.service-grid,.operating-grid,.metric-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .container{width:min(1380px, calc(100% - 24px))}
  .hero{padding-top:228px}
  .lead,.section-head p,.card p,.service-card p,.panel p,.faq-item p,.cta-band p{font-size:1rem}
  .btn{width:100%}
  .lang-switcher select{min-width:0;width:100%}
  .footer-inner{flex-direction:column;align-items:flex-start}
}


/* Static language-page bundle additions */
.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;}

/* Mobile-only header optimization */
.site-header{transition:transform .28s ease,opacity .2s ease,box-shadow .2s ease}
.mobile-toolbar,.mobile-overlay-panel{display:none}
@media (max-width:760px){
  body.mobile-header-enabled .site-header{will-change:transform}
  body.mobile-header-enabled .site-header.is-idle-hidden{transform:translateY(calc(-100% - 12px));opacity:.98}
  .container{width:min(1380px, calc(100% - 22px))}
  .header-inner{
    min-height:60px;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
    gap:8px 10px;
    padding:8px 0;
  }
  .brand{gap:8px;align-items:center}
  .brand-logo{width:38px;height:38px;padding:3px;border-radius:12px;box-shadow:none}
  .brand-title{font-size:1.12rem;letter-spacing:-.025em}
  .brand-tagline,.main-nav,.lang-switcher{display:none!important}
  .mobile-toolbar{display:flex;align-items:center;gap:8px;justify-self:end}
  .mobile-tool-btn{
    width:38px;height:38px;border-radius:12px;border:1px solid rgba(30,78,121,.12);
    background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--blue);
    box-shadow:0 8px 18px rgba(30,78,121,.08);padding:0;cursor:pointer;
  }
  .mobile-tool-btn svg{width:18px;height:18px;display:block}
  .mobile-tool-btn.is-active{background:var(--blue);color:#fff;border-color:var(--blue)}
  .mobile-overlay-panel{
    position:fixed;left:12px;right:12px;top:calc(var(--mobile-header-offset, 60px) + env(safe-area-inset-top, 0px));
    z-index:79;
  }
  .mobile-overlay-panel[hidden]{display:none!important}
  .mobile-overlay-panel.is-open{display:block}
  .mobile-overlay-card{
    background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border:1px solid rgba(219,227,234,.96);
    border-radius:18px;box-shadow:0 18px 42px rgba(18,39,58,.16);padding:10px;
  }
  .mobile-overlay-nav{display:grid;gap:4px}
  .mobile-overlay-nav a{
    display:block;padding:12px 14px;border-radius:12px;font-weight:600;color:#334155;background:#f7fafc;
  }
  .mobile-overlay-nav a:active{background:#eef4f7}
  .mobile-overlay-label{display:block;margin:0 0 8px 2px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#64748b}
  .mobile-overlay-select{
    width:100%;appearance:none;-webkit-appearance:none;
    border:1px solid var(--line);background:var(--bg);border-radius:14px;color:#334155;
    padding:12px 40px 12px 14px;font-size:1rem;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%231E4E79' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;background-size:18px 18px;
  }
  .hero{padding-top:92px}
  .section{padding:26px 0 58px}
  .lead,.section-head p,.card p,.service-card p,.panel p,.faq-item p,.cta-band p{font-size:1rem}
}
@media (max-width:640px){
  .btn{width:100%}
  .footer-inner{flex-direction:column;align-items:flex-start}
}
@media (max-width:520px){
  .container{width:min(1380px, calc(100% - 18px))}
  .header-inner{min-height:56px;padding:7px 0}
  .brand-logo{width:34px;height:34px;border-radius:10px}
  .brand-title{font-size:1.02rem}
  .mobile-tool-btn{width:36px;height:36px;border-radius:11px}
  .mobile-overlay-panel{left:10px;right:10px}
  .hero{padding-top:86px}
}

/* ACLASA methodology page */
.methodology-page .hero-copy h1{font-size:clamp(2.7rem,5.7vw,5.1rem)}
.methodology-note{margin-top:18px;padding:16px 18px;border-radius:20px;background:rgba(212,165,55,.12);border:1px solid rgba(212,165,55,.28);color:#3a3324;line-height:1.75}
.methodology-flow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:24px}
.methodology-step{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow)}
.methodology-step .num{width:34px;height:34px;border-radius:12px;background:rgba(30,78,121,.09);display:grid;place-items:center;color:var(--blue);font-weight:900;margin-bottom:12px}
.methodology-step h3{margin:0;color:var(--blue);font-size:1.05rem;line-height:1.35}
.methodology-step p{margin:10px 0 0;color:var(--muted);line-height:1.7;font-size:.96rem}
.methodology-formula{margin-top:18px;border-radius:26px;padding:24px;background:linear-gradient(135deg,var(--blue),#2b7198);color:#fff;box-shadow:var(--shadow)}
.methodology-formula .formula{font-size:clamp(1.35rem,2.6vw,2.4rem);font-weight:900;letter-spacing:-.03em;line-height:1.16}
.methodology-formula p{color:rgba(255,255,255,.86);line-height:1.8;margin:12px 0 0}
.methodology-table-wrap{overflow-x:auto;margin-top:22px;border-radius:26px;border:1px solid var(--line);box-shadow:var(--shadow)}
.methodology-table{width:100%;border-collapse:collapse;background:#fff;min-width:760px}
.methodology-table th,.methodology-table td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.methodology-table th{background:#f8fafc;color:var(--blue);font-size:.86rem;letter-spacing:.12em;text-transform:uppercase}
.methodology-table tr:last-child td{border-bottom:0}
.band-pill{display:inline-flex;align-items:center;border-radius:999px;padding:7px 12px;background:rgba(59,175,191,.12);color:#176676;font-weight:800;white-space:nowrap}
.band-pill.gold{background:rgba(212,165,55,.17);color:#725316}.band-pill.blue{background:rgba(30,78,121,.11);color:var(--blue)}
.source-list{margin:18px 0 0;padding:0;list-style:none;display:grid;gap:12px}
.source-list li{background:#f4f6f8;border:1px solid var(--line);border-radius:18px;padding:14px 16px;line-height:1.7;color:var(--muted)}
.source-list a{color:var(--blue);font-weight:800;text-decoration:none}.source-list a:hover{text-decoration:underline}
@media (max-width:980px){.methodology-flow{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.methodology-flow{grid-template-columns:1fr}.methodology-table{min-width:650px}}

/* ACLASA workbook download components */
.download-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:22px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:var(--shadow)}
.download-card h2{margin:4px 0 10px;color:var(--blue);font-size:clamp(1.6rem,3vw,2.6rem);letter-spacing:-.03em;line-height:1.12}
.download-card h3{margin:0 0 10px;color:var(--blue);font-size:1.03rem;line-height:1.35}.download-card p{margin:0;color:var(--muted);line-height:1.75}.download-meta{margin-top:12px!important;color:#334155!important}
.workbook-tabs-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}.workbook-tabs-panel{border:1px solid var(--line);border-radius:20px;background:#f8fafc;padding:16px}.workbook-tabs-panel.aclasa{background:rgba(212,165,55,.12);border-color:rgba(212,165,55,.30)}
.workbook-tabs-panel ol{margin:0;padding-left:20px;color:#334155;line-height:1.72}.workbook-tabs-panel li{padding:1px 0}
@media (max-width:760px){.download-card{grid-template-columns:1fr}.download-card .btn{width:100%}.workbook-tabs-grid{grid-template-columns:1fr}}
.workbook-tab-list{margin:0;padding-left:0;list-style:none;color:#334155;line-height:1.72}.workbook-tab-list li{padding:1px 0}


/* ACLASA ISCO-08 value calculator */
.value-calculator-page .hero-copy h1{font-size:clamp(2.65rem,5.5vw,5rem)}
.calculator-shell{display:grid;gap:24px}
.calculator-card{background:#fff;border:1px solid var(--line);border-radius:30px;padding:24px;box-shadow:var(--shadow)}
.calculator-input-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.72fr);gap:18px;align-items:start}
.calculator-label{display:block;margin:0 0 8px;font-size:.82rem;font-weight:900;letter-spacing:.11em;text-transform:uppercase;color:var(--blue)}
.calculator-input,.calculator-select{width:100%;min-height:54px;border:1px solid rgba(30,78,121,.18);border-radius:18px;background:#f8fafc;color:var(--ink);font-size:1.08rem;font-weight:800;padding:0 16px;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.calculator-input:focus,.calculator-select:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(59,175,191,.15)}
.calculator-help{margin:8px 0 0;color:var(--muted);line-height:1.6;font-size:.94rem}
.calculator-examples{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;color:var(--muted);font-weight:700}
.calculator-examples button{border:1px solid rgba(30,78,121,.16);background:rgba(30,78,121,.06);color:var(--blue);border-radius:999px;padding:8px 12px;font-weight:900;cursor:pointer}
.calculator-examples button:hover{background:rgba(59,175,191,.14);border-color:rgba(59,175,191,.38)}
.calculator-status{margin:18px 0 0;padding:13px 15px;border-radius:18px;background:#f4f6f8;border:1px solid var(--line);color:#334155;line-height:1.6;font-weight:700}
.calculator-status.success{background:rgba(76,175,80,.10);border-color:rgba(76,175,80,.24);color:#26642b}
.calculator-status.warning{background:rgba(242,140,40,.10);border-color:rgba(242,140,40,.26);color:#7c3f08}
.calculator-output{display:grid;gap:20px}
.value-result-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:22px;align-items:center;background:linear-gradient(135deg,#fff,#f8fbfc);border:1px solid var(--line);border-radius:30px;padding:26px;box-shadow:var(--shadow)}
.value-result-main h2{margin:4px 0 8px;color:var(--blue);font-size:clamp(1.55rem,3.2vw,2.6rem);letter-spacing:-.035em;line-height:1.08}
.value-muted{margin:0;color:var(--muted);line-height:1.7}
.value-band-tile{min-width:190px;border-radius:26px;background:linear-gradient(135deg,var(--blue),#2b7198);color:#fff;padding:22px;text-align:center;box-shadow:0 18px 40px rgba(30,78,121,.18)}
.value-band-tile span{display:block;font-size:.76rem;letter-spacing:.11em;text-transform:uppercase;opacity:.84;font-weight:900}
.value-band-tile strong{display:block;font-size:clamp(2.2rem,5vw,4rem);letter-spacing:-.05em;line-height:1;margin-top:7px}
.value-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:18px}
.value-kpi{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 10px 26px rgba(18,39,58,.06)}
.value-kpi span{display:block;color:var(--muted);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:900}
.value-kpi strong{display:block;margin-top:8px;color:var(--blue);font-size:1.38rem;line-height:1.12;letter-spacing:-.03em}
.value-explain-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.value-note{background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:0 10px 26px rgba(18,39,58,.06)}
.value-note h3{margin:12px 0 8px;color:var(--blue);font-size:1.15rem}
.value-note p{margin:0 0 8px;color:var(--muted);line-height:1.75}
.value-pill{display:inline-flex;align-items:center;border-radius:999px;padding:7px 11px;font-weight:900;font-size:.82rem;background:rgba(30,78,121,.10);color:var(--blue)}
.value-pill.gold{background:rgba(212,165,55,.17);color:#725316}
.value-pill.success{background:rgba(76,175,80,.12);color:#2f6d33}
.value-pill.warning{background:rgba(242,140,40,.12);color:#854708}
.value-detail-section{margin-top:24px;background:#fff;border:1px solid var(--line);border-radius:30px;padding:24px;box-shadow:var(--shadow)}
.section-head.compact{margin-bottom:16px}
.section-head.compact h2{font-size:clamp(1.45rem,2.4vw,2.2rem)}
.section-head.compact p{max-width:900px}
.value-factor-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.value-factor-card{border:1px solid var(--line);border-radius:22px;padding:17px;background:#f8fafc}
.value-factor-head{display:flex;justify-content:space-between;gap:12px;align-items:start}
.value-factor-head h3{margin:0;color:var(--blue);font-size:1.02rem;line-height:1.25}
.value-factor-head span{display:inline-flex;border-radius:999px;background:rgba(59,175,191,.12);color:#176676;padding:5px 9px;font-weight:900;font-size:.82rem}
.value-factor-score{margin-top:12px;color:var(--ink);font-size:1.2rem;font-weight:900}
.value-progress{height:10px;background:#e9eef2;border-radius:999px;overflow:hidden;margin-top:12px}
.value-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--gold));border-radius:999px}
.value-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:22px;margin-top:14px}
.value-table{width:100%;border-collapse:collapse;background:#fff;min-width:760px}
.value-table th,.value-table td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.value-table th{background:#f8fafc;color:var(--blue);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.value-table tr:last-child td{border-bottom:0}
.subfactor-factor{display:inline-flex;border-radius:999px;background:rgba(30,78,121,.08);color:var(--blue);font-weight:900;padding:5px 9px;white-space:nowrap}
.value-source-list{margin-top:10px}
@media (max-width:980px){
  .calculator-input-grid,.value-result-card,.value-explain-grid{grid-template-columns:1fr}
  .value-band-tile{min-width:0}
  .value-kpi-grid,.value-factor-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .calculator-card,.value-result-card,.value-detail-section{padding:18px;border-radius:24px}
  .value-kpi-grid,.value-factor-grid{grid-template-columns:1fr}
  .value-table{min-width:680px}
}

