
:root{
  --bg:#ffffff;
  --text:#0a0a0a;
  --muted:rgba(10,10,10,0.68);
  --muted-2:rgba(10,10,10,0.45);
  --line:rgba(10,10,10,0.10);
  --card:#fafafa;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{width:min(1120px, calc(100% - 48px)); margin:0 auto}

.site-header{
  position:sticky; top:0; z-index:30;
  background:rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 0;
}
.brand{display:flex; align-items:center; gap:14px}
.brand-logo{width:46px; height:46px; object-fit:contain; border-radius:12px}
.brand-name{
  font-size:1.65rem; font-weight:600; letter-spacing:-0.08em; line-height:1;
}
.brand-name span{color:rgba(10,10,10,0.35)}
.brand-tag{
  margin-top:4px; font-size:10px; letter-spacing:0.34em; text-transform:uppercase; color:var(--muted-2);
}
.nav{display:flex; gap:28px; align-items:center; font-size:12px; text-transform:uppercase; letter-spacing:0.2em; color:rgba(10,10,10,0.60)}
.nav a:hover{color:#000}

.hero{padding:64px 0 56px}
.hero-grid{display:grid; grid-template-columns: 2fr 1fr; gap:40px; align-items:end}
.eyebrow-pill{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line); border-radius:999px;
  padding:8px 14px; font-size:11px; text-transform:uppercase; letter-spacing:0.22em; color:rgba(10,10,10,0.55)
}
.dot{width:14px; height:14px; border-radius:50%; background:#0a0a0a}
.hero h1{
  margin:24px 0 0; max-width:900px; font-size:clamp(3rem, 7vw, 7rem);
  line-height:0.95; letter-spacing:-0.06em; font-weight:500;
}
.hero-text{
  margin-top:28px; max-width:720px; font-size:18px; line-height:1.9; color:var(--muted);
}
.positioning-card,.stat-card,.service-card,.proof-card,.palette-card,.text-card{
  border:1px solid var(--line); border-radius:32px; background:#fff;
}
.positioning-card{padding:24px}
.section-label,.eyebrow{
  font-size:11px; text-transform:uppercase; letter-spacing:0.24em; color:var(--muted-2);
}
.positioning-list{margin-top:20px}
.positioning-list p{
  margin:0 0 14px; color:rgba(10,10,10,0.72); font-size:14px; line-height:1.8;
}
.positioning-note{margin-top:28px; display:flex; align-items:center; gap:10px; font-size:14px}
.arrow-badge{
  display:inline-flex; width:36px; height:36px; border-radius:999px;
  align-items:center; justify-content:center; border:1px solid var(--line)
}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:56px}
.stat-card{padding:20px; background:rgba(10,10,10,0.02)}
.stat-value{font-size:clamp(1.6rem, 2vw, 2.4rem); letter-spacing:-0.04em}
.stat-label{margin-top:8px; font-size:14px; color:rgba(10,10,10,0.60); line-height:1.7}

.section{border-top:1px solid var(--line); padding:56px 0 80px}
.section-grid{display:grid; grid-template-columns:220px 1fr; gap:32px}
.section-content h2{
  margin:0; font-size:clamp(2rem, 4vw, 3.5rem); line-height:1.05; letter-spacing:-0.04em; font-weight:500;
}
.two-col-text{
  margin-top:32px; display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
  color:var(--muted); line-height:2;
}
.card-grid{display:grid; gap:16px; margin-top:32px}
.card-grid.two{grid-template-columns:repeat(2,1fr)}
.card-grid.four{grid-template-columns:repeat(4,1fr)}
.service-card{padding:24px 24px 28px; transition:background .2s ease}
.service-card:hover{background:rgba(10,10,10,0.02)}
.card-icon{
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line); border-radius:12px; font-size:18px
}
.service-card h3{margin:18px 0 0; font-size:22px; letter-spacing:-0.03em}
.service-card p{margin:12px 0 0; font-size:15px; line-height:1.9; color:var(--muted)}
.proof-card{padding:28px}
.proof-label{display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(10,10,10,0.55)}
.proof-card ul{margin:22px 0 0; padding-left:20px; color:rgba(10,10,10,0.72); line-height:2}
.proof-card p{margin:22px 0 0; color:rgba(10,10,10,0.72); line-height:2}
.chips-grid{
  margin-top:28px; display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
.chips-grid span{
  border:1px solid var(--line); border-radius:999px; padding:14px 16px; font-size:14px; color:rgba(10,10,10,0.72)
}
.identity-logo-wrap{
  margin-top:20px; border:1px solid var(--line); border-radius:24px; background:#fafafa; padding:24px;
  display:flex; justify-content:center; align-items:center;
}
.identity-logo{max-width:220px; width:100%; height:auto}
.palette-card{padding:16px; margin-top:20px}
.palette-row{display:flex; align-items:center; gap:14px; margin-bottom:14px}
.palette-row:last-child{margin-bottom:0}
.palette-row strong{display:block; font-size:14px}
.palette-row small{display:block; color:var(--muted-2); margin-top:4px}
.swatch{width:40px; height:40px; border-radius:999px}
.swatch-white{background:#fff; border:1px solid var(--line)}
.swatch-black{background:#0A0A0A}
.swatch-gray{background:#E9E9E7; border:1px solid var(--line)}
.text-card{padding:16px; margin-top:16px; font-size:14px; color:var(--muted); line-height:1.9}
.text-card p{margin:0 0 10px}
.text-card p:last-child{margin-bottom:0}
.contact-text{margin:0; font-size:16px; line-height:2; color:var(--muted)}
.menu-list{margin-top:18px}
.menu-list div{
  display:flex; justify-content:space-between; align-items:center; gap:8px;
  padding:12px 0; border-bottom:1px solid var(--line); font-size:14px; color:rgba(10,10,10,0.72)
}
.contact-bar{
  margin-top:28px; display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  border:1px solid var(--line); border-radius:24px; padding:18px 20px; background:#fafafa
}
.contact-logo{width:44px; height:44px; object-fit:contain; border-radius:12px}
.contact-link{font-size:18px; font-weight:500; letter-spacing:-0.02em}
.contact-link:hover{text-decoration:underline}

@media (max-width: 1100px){
  .card-grid.four,.chips-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 820px){
  .container{width:min(100% - 32px, 1120px)}
  .nav{display:none}
  .hero-grid,.section-grid,.card-grid.two,.two-col-text{grid-template-columns:1fr}
  .card-grid.four,.chips-grid,.stats-grid{grid-template-columns:1fr}
  .section{padding:44px 0 60px}
  .hero{padding:48px 0 48px}
}
