/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:#fff;color:#1a1a1a;overflow-x:hidden;line-height:1.8;-webkit-font-smoothing:antialiased;font-feature-settings:'palt';font-size:18px}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.serif{font-family:'Shippori Mincho',serif}
.gold{color:#a07830}

/* ===== HEADER ===== */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;padding:10px 16px;display:flex;justify-content:space-between;align-items:center;background:#fff;backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.hd-logo{font-family:'Shippori Mincho',serif;font-size:.85rem;font-weight:700;letter-spacing:.04em}
.hd-logo span{color:#a07830}
.hd-cta{font-size:.68rem;color:#fff;background:#06C755;padding:7px 14px;border-radius:4px;font-weight:700}

/* ===== LINE CTA ===== */
.line-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:#06C755;color:#fff;font-size:1.05rem;font-weight:800;padding:18px 24px;border-radius:6px;width:100%;max-width:400px;margin:0 auto;transition:all .2s;box-shadow:0 4px 16px rgba(6,199,85,.25)}
.line-btn:hover{background:#05b34c;transform:translateY(-1px);box-shadow:0 6px 20px rgba(6,199,85,.3)}
.line-btn svg{flex-shrink:0}
.cta-note{font-size:.7rem;color:rgba(0,0,0,.35);margin-top:10px;text-align:center;line-height:1.6}
.cta-block{padding:28px 20px}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:#0e0e0e}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.32) contrast(1.1)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.7) 50%,rgba(0,0,0,.3) 100%)}
@media(max-width:640px){.hero-bg::after{background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,rgba(0,0,0,.65) 60%,rgba(0,0,0,.5) 100%)}}
.hero-content{position:relative;z-index:2;width:100%;padding:80px 20px 32px;color:#fff}
.hero-tag{display:inline-block;font-size:.65rem;letter-spacing:.15em;color:#c8a45e;border:1px solid rgba(200,164,94,.3);padding:5px 12px;margin-bottom:20px;font-weight:600}
.hero-h{font-family:'Shippori Mincho',serif;font-size:clamp(1.7rem,7vw,2.8rem);font-weight:800;line-height:1.5;letter-spacing:.02em;margin-bottom:16px;text-shadow:0 2px 8px rgba(0,0,0,.8),0 0 30px rgba(0,0,0,.5)}
.hero-h .gold{color:#c8a45e}
.hero-sub{font-size:.9rem;color:rgba(255,255,255,.72);line-height:2;margin-bottom:28px;text-shadow:0 1px 6px rgba(0,0,0,.7),0 0 20px rgba(0,0,0,.4)}
.hero-sub strong{color:#c8a45e}
.hero-nums{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:28px}
.hero-num{text-align:center;background:rgba(0,0,0,.35);border-radius:6px;padding:12px 4px;backdrop-filter:blur(4px)}
.hero-num .n{font-family:'Shippori Mincho',serif;font-size:1.6rem;font-weight:800;color:#c8a45e;line-height:1}
.hero-num .u{font-size:.6rem;color:#c8a45e;font-weight:700}
.hero-num .l{font-size:.55rem;color:rgba(255,255,255,.4);margin-top:2px}
.hero .line-btn{max-width:100%}

/* ===== SECTION ===== */
.sec{padding:48px 20px}
.sec-label{font-size:.58rem;letter-spacing:.2em;color:#a07830;margin-bottom:8px;font-weight:600}
.sec-h{font-family:'Shippori Mincho',serif;font-size:clamp(1.25rem,5vw,1.7rem);font-weight:700;line-height:1.6;margin-bottom:16px;letter-spacing:.02em}
.sec-text{font-size:1rem;color:rgba(0,0,0,.7);line-height:2.1;margin-bottom:24px}
.divider{height:1px;background:rgba(0,0,0,.06);margin:0 20px}
.sec-gray{background:#f7f7f5}

/* ===== PROBLEM LIST ===== */
.problem-list{list-style:none;margin-bottom:20px}
.problem-list li{font-size:1rem;color:rgba(0,0,0,.75);line-height:2;padding:14px 0;border-bottom:1px solid rgba(0,0,0,.05);padding-left:24px;position:relative}
.problem-list li::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:rgba(200,60,60,.4)}

/* ===== COMPARE ===== */
.compare{width:100%;border-collapse:collapse;font-size:.82rem;margin-bottom:20px}
.compare th{text-align:left;padding:10px 12px;border-bottom:2px solid rgba(0,0,0,.08);color:rgba(0,0,0,.35);font-weight:500;font-size:.68rem;letter-spacing:.04em}
.compare td{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.05);color:rgba(0,0,0,.65)}
.compare td:first-child{color:rgba(0,0,0,.4);font-weight:500;white-space:nowrap;width:72px}
.compare td:last-child{color:#a07830;font-weight:700}
.compare tr:last-child td{border-bottom:none}

/* ===== WHY CHEAP ===== */
.reason-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:20px}
.reason-card{background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:8px;padding:20px}
.reason-card strong{display:block;font-size:.95rem;margin-bottom:8px;color:#1a1a1a}
.reason-card p{font-size:.92rem;color:rgba(0,0,0,.65);line-height:2}

/* ===== PRICING ===== */
.pricing-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 20px 16px;margin:0 -20px}
.pricing-scroll::-webkit-scrollbar{display:none}
.price-card{flex:0 0 280px;scroll-snap-align:center;background:#fafafa;border:1.5px solid rgba(0,0,0,.07);border-radius:10px;padding:28px 20px;text-align:center;position:relative}
.price-card.featured{border-color:#a07830;background:linear-gradient(180deg,rgba(160,120,48,.03),#fff);box-shadow:0 4px 20px rgba(160,120,48,.08)}
.price-card.featured::before{content:'おすすめ';position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:#a07830;color:#fff;font-size:.58rem;font-weight:800;padding:3px 12px;border-radius:3px;letter-spacing:.06em}
.price-name{font-family:'Shippori Mincho',serif;font-size:1rem;font-weight:700;margin-bottom:2px}
.price-speed{font-size:.72rem;color:#a07830;font-weight:700;margin-bottom:12px}
.price-amount{font-family:'Shippori Mincho',serif;font-size:2rem;font-weight:800;line-height:1}
.price-amount span{color:#a07830}
.price-tax{font-size:.6rem;color:rgba(0,0,0,.3);margin-top:2px;margin-bottom:16px}
.price-features{list-style:none;text-align:left;font-size:.85rem;color:rgba(0,0,0,.65);line-height:2.2}
.price-features li::before{content:'\2713';color:#a07830;font-weight:700;margin-right:6px}
.pricing-hint{font-size:.68rem;color:rgba(0,0,0,.3);text-align:center;margin-top:4px}

/* ===== WORKS GALLERY ===== */
.works-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 20px 12px;margin:0 -20px}
.works-scroll::-webkit-scrollbar{display:none}
.work-card{flex:0 0 260px;scroll-snap-align:center;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.06);background:#fafafa;text-decoration:none;color:inherit}
.work-card-img{height:160px;background:#e8e8e6;display:flex;align-items:center;justify-content:center;color:rgba(0,0,0,.2);font-size:.7rem;overflow:hidden}
.work-card-img img{width:100%;height:100%;object-fit:cover}
.work-card-body{padding:14px 16px}
.work-card-body .tag{font-size:.58rem;color:#a07830;letter-spacing:.08em;margin-bottom:2px}
.work-card-body .name{font-size:.85rem;font-weight:700}
.work-card-body .desc{font-size:.65rem;color:rgba(0,0,0,.4);margin-top:1px}

/* ===== BEFORE/AFTER ===== */
.ba-grid{display:grid;grid-template-columns:1fr;gap:12px}
.ba-card{border-radius:8px;padding:20px}
.ba-card.before{background:rgba(200,60,60,.03);border:1px solid rgba(200,60,60,.1)}
.ba-card.after{background:rgba(160,120,48,.03);border:1px solid rgba(160,120,48,.15)}
.ba-card h4{font-size:.88rem;font-weight:700;margin-bottom:10px}
.ba-card.before h4{color:#c45050}
.ba-card.after h4{color:#a07830}
.ba-card p{font-size:.82rem;color:rgba(0,0,0,.7);line-height:2.2}

/* ===== FLOW ===== */
.flow-list{display:flex;flex-direction:column;gap:0}
.flow-item{display:flex;gap:16px;align-items:flex-start;padding:20px 0;position:relative}
.flow-item:not(:last-child)::after{content:'';position:absolute;left:27px;top:68px;bottom:0;width:1px;background:rgba(0,0,0,.08)}
.flow-icon{width:56px;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.flow-icon img{width:100%;height:100%;object-fit:contain;opacity:.6}
.flow-body{flex:1;padding-top:4px}
.flow-num{font-size:.6rem;color:#a07830;font-weight:700;letter-spacing:.08em;margin-bottom:2px}
.flow-title{font-size:.92rem;font-weight:700;margin-bottom:2px}
.flow-desc{font-size:.82rem;color:rgba(0,0,0,.6);line-height:1.7}

/* ===== FAQ ===== */
.faq-item{padding:16px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.faq-q{font-size:.9rem;font-weight:700;margin-bottom:6px}
.faq-a{font-size:.88rem;color:rgba(0,0,0,.65);line-height:1.9}

/* ===== MERIT (used by salon, seizou, ashiba, juku, keibi, kaitai, jinzai, shindan etc.) ===== */
.merit-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:20px}
.merit-card{background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:8px;padding:20px}
.merit-card strong{display:block;font-size:.95rem;margin-bottom:8px;color:#1a1a1a}
.merit-card p{font-size:.92rem;color:rgba(0,0,0,.65);line-height:2}
.merit-card .merit-num{font-family:'Shippori Mincho',serif;font-size:.7rem;color:#a07830;font-weight:700;letter-spacing:.08em;margin-bottom:6px}
.merit-num{font-family:'Shippori Mincho',serif;font-size:.7rem;color:#a07830;font-weight:700;letter-spacing:.08em;margin-bottom:4px}

/* ===== SPEC (used by tax, sharoushi etc.) ===== */
.spec-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:20px}
.spec-card{background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:8px;padding:20px}
.spec-card strong{display:block;font-size:.95rem;margin-bottom:8px;color:#1a1a1a}
.spec-card p{font-size:.92rem;color:rgba(0,0,0,.65);line-height:2}

/* ===== STAT BOX (used by insurance, koumuten, juku etc.) ===== */
.stat-box{background:linear-gradient(135deg,rgba(160,120,48,.04),rgba(160,120,48,.08));border:1px solid rgba(160,120,48,.15);border-radius:10px;padding:28px 24px;text-align:center;margin-bottom:24px}
.stat-num{font-family:'Shippori Mincho',serif;font-size:clamp(2.4rem,8vw,3.6rem);font-weight:800;color:#a07830;line-height:1.2}
.stat-num span{font-size:1.4rem}
.stat-label{font-size:.85rem;color:rgba(0,0,0,.55);margin-top:4px}
.stat-desc{font-size:.85rem;color:rgba(0,0,0,.7);margin-top:8px;line-height:1.8}
.stat-source{font-size:.65rem;color:rgba(0,0,0,.3);margin-top:8px}

/* ===== STAT GRID (used by shiho etc.) ===== */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.stat-card{background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:8px;padding:20px;text-align:center}
.stat-card .n{font-family:'Shippori Mincho',serif;font-size:2rem;font-weight:800;color:#a07830;line-height:1.2}
.stat-card .u{font-size:.7rem;color:#a07830;font-weight:700}
.stat-card .l{font-size:.65rem;color:rgba(0,0,0,.35);margin-top:4px;line-height:1.4}

/* ===== STRENGTH (used by koumuten etc.) ===== */
.strength-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:20px}
.strength-card{background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:10px;padding:24px 20px}
.strength-card .num{font-family:'Shippori Mincho',serif;font-size:1.4rem;font-weight:800;color:#a07830;margin-bottom:4px}
.strength-card h3{font-size:.95rem;font-weight:700;margin-bottom:8px;line-height:1.5}
.strength-card p{font-size:.88rem;color:rgba(0,0,0,.7);line-height:2}

/* ===== PORTAL COST (used by reform etc.) ===== */
.portal-cost{background:#fafafa;border:1px solid rgba(0,0,0,.06);border-radius:10px;padding:24px 20px;margin-bottom:20px}
.portal-cost .cost-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.05);font-size:.88rem;color:rgba(0,0,0,.65)}
.portal-cost .cost-row:last-child{border-bottom:none}
.portal-cost .cost-row .label{color:rgba(0,0,0,.5)}
.portal-cost .cost-row .value{font-weight:700;color:#c45050}
.portal-cost .cost-row.highlight .value{color:#a07830;font-size:1.1rem}

/* ===== INDUSTRY (used by kousoku-top) ===== */
.industry-section{padding:0 20px;margin-bottom:40px}
.industry-cat-label{font-size:.68rem;letter-spacing:.15em;color:#a07830;font-weight:700;margin-bottom:10px;padding-left:10px;border-left:3px solid #a07830}
.industry-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
.industry-card{display:block;background:#fff;border:1.5px solid rgba(0,0,0,.06);border-radius:10px;padding:20px 14px;text-align:center;transition:all .25s;position:relative;overflow:hidden}
.industry-card:hover{border-color:#a07830;box-shadow:0 4px 20px rgba(160,120,48,.1);transform:translateY(-2px)}
.industry-card::after{content:'\2192';position:absolute;top:10px;right:12px;font-size:.65rem;color:rgba(0,0,0,.15);transition:color .25s}
.industry-card:hover::after{color:#a07830}
.industry-icon{width:44px;height:44px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;background:rgba(160,120,48,.06);border-radius:50%}
.industry-icon svg{width:22px;height:22px}
.industry-name{font-family:'Shippori Mincho',serif;font-size:.85rem;font-weight:700;margin-bottom:3px;line-height:1.4}
.industry-tag{font-size:.6rem;color:rgba(0,0,0,.4);line-height:1.5}
.industry-card.wide{grid-column:1/-1;display:flex;align-items:center;gap:16px;text-align:left;padding:20px 24px}
.industry-card.wide .industry-icon{margin:0;flex-shrink:0}
.industry-card.wide .industry-name{margin-bottom:0}

/* ===== FINAL CTA ===== */
.final{position:relative;padding:64px 20px;text-align:center;overflow:hidden;background:#0e0e0e}
.final-bg{position:absolute;inset:0}
.final-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.18) contrast(1.1)}
.final-content{position:relative;z-index:2;color:#fff}
.final-content .sec-h{color:#fff}
.final-content .gold{color:#c8a45e}
.final .line-btn{max-width:100%}

/* ===== FOOTER ===== */
.ft{padding:24px 20px;text-align:center;background:#f5f5f3}
.ft a{color:rgba(0,0,0,.2);font-size:.55rem;margin:0 6px}
.ft a:hover{color:#a07830}
.ft-c{color:rgba(0,0,0,.1);font-size:.48rem;margin-top:4px}

/* ===== MOBILE CTA BAR ===== */
.mob{position:fixed;bottom:0;left:0;right:0;z-index:99;background:#06C755;padding:10px 16px;text-align:center;display:block}
.mob a{color:#fff;font-weight:800;font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:6px}
body{padding-bottom:44px}

/* ===== PHOTO BREAK ===== */
.photo-break{position:relative;height:40vh;min-height:240px;overflow:hidden}
.photo-break img{width:100%;height:100%;object-fit:cover;filter:brightness(.4) contrast(1.05)}
.photo-break-content{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;padding:20px}
.photo-break-h{font-family:'Shippori Mincho',serif;font-size:clamp(1.1rem,4.5vw,1.6rem);font-weight:700;text-align:center;line-height:1.7;color:#fff}
.photo-break-h .gold{color:#c8a45e}

/* ===== FADE ===== */
.fi{opacity:0;transform:translateY(12px);transition:opacity .6s,transform .6s}
.fi.v{opacity:1;transform:none}

/* ===== LINE SVG inline helper ===== */
.line-svg{display:inline-block;vertical-align:middle}

/* ===== PC LAYOUT ===== */
@media(min-width:768px){
  /* Global */
  body{font-size:20px;padding-bottom:0}
  .mob{display:none}
  .sec{padding:80px 40px;max-width:900px;margin-left:auto;margin-right:auto}
  .sec-label{font-size:.7rem;letter-spacing:.25em;margin-bottom:12px}
  .sec-h{font-size:clamp(2rem,3.5vw,2.6rem);margin-bottom:28px}
  .sec-text{font-size:1.1rem;line-height:2.3;margin-bottom:32px}
  .divider{max-width:900px;margin-left:auto;margin-right:auto}
  .pricing-hint{display:none}

  /* Header */
  .hd{padding:12px 40px}
  .hd-logo{font-size:1rem}
  .hd-cta{font-size:.75rem;padding:8px 20px}

  /* Hero */
  .hero{min-height:90vh}
  .hero-content{max-width:1100px;margin:0 auto;padding:140px 60px 80px}
  .hero-h{font-size:clamp(2.2rem,4vw,3.2rem)}
  .hero-sub{font-size:1.05rem;max-width:520px}
  .hero-nums{max-width:520px;gap:12px}
  .hero-num{padding:16px 8px}
  .hero-num .n{font-size:2rem}
  .hero .line-btn{max-width:400px;margin:0}

  /* CTA blocks */
  .cta-block{padding:32px 40px;max-width:840px;margin:0 auto}
  .line-btn{max-width:400px;font-size:1.08rem;padding:20px 32px}

  /* Problem list */
  .problem-list li{font-size:1.08rem;line-height:2;padding:14px 0;padding-left:28px}

  /* Compare table */
  .compare{font-size:1.02rem}
  .compare th{font-size:.8rem;padding:16px 24px}
  .compare td{padding:16px 24px}

  /* Why cheap */
  .reason-grid{grid-template-columns:1fr 1fr;gap:20px}
  .reason-card{padding:32px}
  .reason-card strong{font-size:1.15rem;margin-bottom:10px}
  .reason-card p{font-size:1.05rem;line-height:2.2}

  /* Merit */
  .merit-grid{grid-template-columns:1fr 1fr;gap:20px}
  .merit-card{padding:32px}
  .merit-card strong{font-size:1.15rem;margin-bottom:10px}
  .merit-card p{font-size:1.05rem;line-height:2.2}

  /* Spec */
  .spec-grid{grid-template-columns:1fr 1fr;gap:20px}
  .spec-card{padding:28px}
  .spec-card strong{font-size:1.05rem}
  .spec-card p{font-size:.95rem;line-height:2.2}

  /* Stat box */
  .stat-box{padding:40px 32px}
  .stat-num{font-size:4rem}
  .stat-label{font-size:1rem}

  /* Stat grid */
  .stat-grid{gap:20px}
  .stat-card{padding:32px}
  .stat-card .n{font-size:2.6rem}

  /* Strength */
  .strength-grid{grid-template-columns:1fr 1fr;gap:20px}
  .strength-card{padding:32px 28px}
  .strength-card h3{font-size:1.1rem}
  .strength-card p{font-size:1rem;line-height:2.2}

  /* Portal cost */
  .portal-cost{padding:32px 28px}
  .portal-cost .cost-row{font-size:1rem;padding:14px 0}

  /* Industry */
  .industry-section{max-width:900px;margin-left:auto;margin-right:auto;padding:0 40px;margin-bottom:48px}
  .industry-cat-label{font-size:.78rem;margin-bottom:14px}
  .industry-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
  .industry-card{padding:28px 16px}
  .industry-icon{width:52px;height:52px;margin-bottom:14px}
  .industry-icon svg{width:26px;height:26px}

  /* Pricing */
  .pricing-scroll{overflow:visible;flex-wrap:nowrap;justify-content:center;padding:0 40px;margin:0;gap:20px}
  .price-card{flex:0 0 280px;padding:36px 28px}
  .price-card.featured{transform:scale(1.04)}
  .price-name{font-size:1.15rem}
  .price-speed{font-size:.82rem}
  .price-amount{font-size:2.4rem}
  .price-features{font-size:.92rem;line-height:2.4}

  /* Works */
  .works-scroll{overflow:visible;flex-wrap:wrap;justify-content:center;padding:0 40px;margin:0;gap:14px}
  .work-card{flex:0 0 calc(20% - 14px);min-width:180px}
  .work-card-img{height:120px}

  /* Before/After */
  .ba-grid{grid-template-columns:1fr 1fr;gap:20px}
  .ba-card{padding:28px}
  .ba-card h4{font-size:1.02rem}
  .ba-card p{font-size:.92rem;line-height:2.4}

  /* Flow */
  .flow-list{flex-direction:row;gap:28px}
  .flow-item{flex:1;flex-direction:column;text-align:center;align-items:center;padding:0}
  .flow-item:not(:last-child)::after{display:none}
  .flow-icon{width:72px;height:72px;margin-bottom:16px}
  .flow-body{padding:0;text-align:center}
  .flow-title{font-size:1rem}
  .flow-desc{font-size:.85rem}

  /* Photo break */
  .photo-break{height:45vh;min-height:360px}
  .photo-break-h{font-size:clamp(1.4rem,2.5vw,2rem)}

  /* Final CTA */
  .final{padding:100px 40px}
  .final-content{max-width:700px;margin:0 auto}
  .final-content .sec-h{font-size:clamp(1.6rem,3vw,2.2rem)}
  .final .line-btn{max-width:400px}

  /* FAQ */
  .faq-item{padding:24px 0}
  .faq-q{font-size:1.1rem}
  .faq-a{font-size:1rem;line-height:2}

  /* Footer */
  .ft{padding:32px 40px}
}
/* ===== COST TABLE (ホットペッパー vs 自社HP) ===== */
.cost-table{width:100%;border-collapse:collapse;font-size:.82rem;margin:24px 0 16px;border-radius:10px;overflow:hidden;border:1.5px solid rgba(0,0,0,.07)}
.cost-table th{text-align:center;padding:14px 12px;font-weight:600;font-size:.72rem;letter-spacing:.04em;border-bottom:2px solid rgba(0,0,0,.08)}
.cost-table th:first-child{width:90px;background:transparent}
.cost-table th:nth-child(2){background:rgba(0,0,0,.03);color:rgba(0,0,0,.45)}
.cost-table th:nth-child(3){background:rgba(160,120,48,.06);color:#a07830}
.cost-table td{padding:12px;border-bottom:1px solid rgba(0,0,0,.05);text-align:center;vertical-align:middle}
.cost-table td:first-child{text-align:left;color:rgba(0,0,0,.5);font-weight:600;font-size:.78rem;white-space:nowrap;background:#fafafa}
.cost-table td:nth-child(2){color:rgba(0,0,0,.55);background:rgba(0,0,0,.015)}
.cost-table td:nth-child(3),.cost-table td.highlight{color:#a07830;font-weight:700;background:rgba(160,120,48,.03)}
.cost-table tr:last-child td{border-bottom:none}
@media(min-width:768px){
  .cost-table{font-size:1rem}
  .cost-table th{font-size:.82rem;padding:18px 24px}
  .cost-table td{padding:16px 24px}
}
