/* ============================================================
   Pattern A — "Corporate Navy x Gold"
   Trustworthy, professional buyback service
   ============================================================ */

/* --- Reset & Base --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --primary:#1a2a4a;
  --primary-light:#2a3f6a;
  --primary-dark:#0f1a30;
  --accent:#c8a45c;
  --accent-light:#ddc07a;
  --accent-dark:#a8863c;
  --bg:#ffffff;
  --bg-alt:#f5f3ee;
  --bg-dark:#1a2a4a;
  --text:#333333;
  --text-light:#666666;
  --text-white:#ffffff;
  --border:#e0ddd5;
  --shadow:0 4px 20px rgba(26,42,74,.12);
  --shadow-lg:0 12px 40px rgba(26,42,74,.18);
  --radius:12px;
  --radius-lg:16px;
  --transition:all .3s ease;
  --container:1200px;
  --header-h:80px;
}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:'Noto Sans JP',sans-serif;font-weight:400;color:var(--text);background:var(--bg);line-height:1.8;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;transition:var(--transition)}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* --- Header --- */
.header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);background:rgba(26,42,74,.95);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid rgba(200,164,92,.2)}
.header-inner{max-width:var(--container);margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:40px;height:40px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--primary)}
.logo-text{font-size:18px;font-weight:700;color:var(--text-white)}
.logo-accent{color:var(--accent)}
.nav{display:flex;align-items:center;gap:24px}
.nav a{color:rgba(255,255,255,.8);font-size:14px;font-weight:500;transition:var(--transition)}
.nav a:hover{color:var(--accent)}
.nav-cta{background:var(--accent);color:var(--primary)!important;padding:10px 24px;border-radius:var(--radius);font-weight:700;font-size:14px}
.nav-cta:hover{background:var(--accent-light);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-white);transition:var(--transition)}

/* --- Hero --- */
.hero{position:relative;min-height:600px;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,var(--primary-light) 100%);z-index:0}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(200,164,92,.15) 0%,transparent 60%)}
.hero-content{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:0 20px;text-align:center;color:var(--text-white)}
.hero-badge{display:inline-block;background:rgba(200,164,92,.2);border:1px solid rgba(200,164,92,.4);padding:8px 24px;border-radius:50px;font-size:14px;font-weight:500;color:var(--accent);margin-bottom:24px}
.hero-small{font-size:18px;font-weight:400;margin-bottom:8px;color:rgba(255,255,255,.8)}
.hero-large{font-size:48px;font-weight:900;line-height:1.3;margin-bottom:16px}
.hero-highlight{color:var(--accent);position:relative}
.hero-sub{font-size:18px;color:rgba(255,255,255,.7);margin-bottom:40px;line-height:1.8}
.hero-points{display:flex;justify-content:center;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.hero-point{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:500}
.hero-point-icon{width:28px;height:28px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--primary)}
.hero-cta{display:flex;justify-content:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.hero-note{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:32px}
.hero-scroll{display:inline-flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:13px;cursor:pointer;transition:var(--transition)}
.hero-scroll:hover{color:var(--accent)}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;transition:var(--transition);border:none;font-family:inherit;text-align:center;line-height:1.4}
.btn-primary{background:var(--accent);color:var(--primary);box-shadow:0 4px 15px rgba(200,164,92,.4)}
.btn-primary:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:0 6px 25px rgba(200,164,92,.5)}
.btn-outline{background:transparent;border:2px solid var(--accent);color:var(--accent)}
.btn-outline:hover{background:var(--accent);color:var(--primary)}
.btn-lg{padding:18px 40px;font-size:18px}
.btn-sm{padding:10px 20px;font-size:14px}
.btn-full{width:100%}
.btn-line{background:#06c755;color:#fff}
.btn-line:hover{background:#05b04a;transform:translateY(-2px)}
.btn-phone{background:var(--primary);color:var(--text-white)}
.btn-phone:hover{background:var(--primary-light);transform:translateY(-2px)}
.pulse{animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,164,92,.5)}70%{box-shadow:0 0 0 15px rgba(200,164,92,0)}100%{box-shadow:0 0 0 0 rgba(200,164,92,0)}}

/* --- Stats Bar --- */
.stats-bar{background:var(--accent);padding:40px 0;color:var(--primary)}
.stats-grid{max-width:var(--container);margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-number{font-size:36px;font-weight:900;line-height:1.2}
.stat-unit{font-size:16px;font-weight:500}
.stat-label{font-size:13px;font-weight:400;opacity:.8;margin-top:4px}

/* --- Section Titles --- */
.section-title{font-size:32px;font-weight:900;text-align:center;margin-bottom:16px;line-height:1.4}
.text-accent{color:var(--accent)}
.section-sub{text-align:center;color:var(--text-light);font-size:16px;margin-bottom:48px;line-height:1.8}
.text-large{font-size:18px}

/* --- Problems --- */
.problems{padding:80px 0;background:var(--bg-alt)}
.problems-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}
.problem-card{background:var(--bg);border-radius:var(--radius);padding:32px 24px;text-align:center;box-shadow:var(--shadow);transition:var(--transition);border:1px solid var(--border)}
.problem-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.problem-icon{font-size:40px;margin-bottom:16px}
.problems-answer{text-align:center;padding:40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--radius-lg);color:var(--text-white)}
.problems-arrow{font-size:32px;text-align:center;margin-bottom:24px;color:var(--accent)}

/* --- Reasons --- */
.reasons{padding:80px 0;background:var(--bg)}
.reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reason-card{background:var(--bg);border-radius:var(--radius);padding:32px 24px;text-align:center;box-shadow:var(--shadow);border:1px solid var(--border);transition:var(--transition);position:relative;overflow:hidden}
.reason-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.reason-number{position:absolute;top:12px;left:16px;font-size:48px;font-weight:900;color:rgba(200,164,92,.15);line-height:1}
.reason-icon{font-size:40px;margin-bottom:16px}

/* --- Products --- */
.products{padding:80px 0;background:var(--bg-alt)}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.product-card{background:var(--bg);border-radius:var(--radius);padding:32px 24px;text-align:center;box-shadow:var(--shadow);border:1px solid var(--border);transition:var(--transition)}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.product-icon{font-size:48px;margin-bottom:16px}
.product-price{color:var(--accent);font-size:20px;font-weight:700;margin-top:8px}

/* --- Client Types --- */
.client-types{padding:80px 0;background:var(--bg)}
.client-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:800px;margin:0 auto}
.client-card{background:var(--bg);border-radius:var(--radius-lg);padding:40px 32px;text-align:center;box-shadow:var(--shadow);border:2px solid var(--border);transition:var(--transition);cursor:pointer}
.client-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.client-icon{font-size:48px;margin-bottom:16px}

/* --- Condition Tabs --- */
.condition-tabs{display:flex;justify-content:center;gap:0;margin-bottom:32px;border:2px solid var(--primary);border-radius:50px;overflow:hidden;max-width:400px;margin-left:auto;margin-right:auto}
.condition-tab{flex:1;padding:12px 24px;text-align:center;font-size:15px;font-weight:700;cursor:pointer;transition:var(--transition);background:transparent;color:var(--primary);border:none;font-family:inherit}
.condition-tab.active{background:var(--primary);color:var(--text-white)}
.condition-tab:hover:not(.active){background:rgba(26,42,74,.08)}
.condition-content{display:none}
.condition-content.active{display:block}

/* --- Price --- */
.price-table{padding:80px 0;background:var(--bg-alt)}
.price-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:32px;flex-wrap:wrap}
.price-tab{padding:10px 24px;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;transition:var(--transition);border:2px solid var(--border);background:var(--bg);color:var(--text)}
.price-tab.active{background:var(--primary);color:var(--text-white);border-color:var(--primary)}
.price-content{display:none}
.price-content.active{display:block}
.price-list{display:grid;gap:12px}
.price-list li{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}
.price-high{color:var(--accent);font-size:20px;font-weight:700}
.price-note{text-align:center;margin-top:24px;color:var(--text-light);font-size:14px}

/* --- Flow --- */
.flow{padding:80px 0;background:var(--bg)}
.flow-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.flow-step{text-align:center;padding:24px;position:relative}
.flow-number{width:48px;height:48px;background:var(--primary);color:var(--text-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;margin:0 auto 16px}
.flow-icon{font-size:40px;margin-bottom:12px}
.flow-arrow{position:absolute;right:-16px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:24px}

/* --- Notice --- */
.notice{padding:80px 0;background:var(--bg-alt)}
.notice-box{background:var(--bg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.notice-header{background:var(--primary);color:var(--text-white);padding:24px 32px;display:flex;align-items:center;gap:12px;font-size:18px;font-weight:700}
.notice-icon{font-size:24px}
.notice-body{padding:32px}
.notice-item{padding:16px 0;border-bottom:1px solid var(--border);display:flex;gap:12px;align-items:flex-start}
.notice-item:last-child{border-bottom:none}
.notice-item-primary{background:rgba(200,164,92,.08);padding:16px;border-radius:var(--radius);border:1px solid rgba(200,164,92,.2);margin-bottom:16px}
.notice-timeline{padding:24px 0}
.notice-timeline-item{display:flex;gap:16px;padding-bottom:24px;position:relative}
.notice-timeline-item::before{content:'';position:absolute;left:18px;top:40px;bottom:0;width:2px;background:var(--border)}
.notice-timeline-item:last-child::before{display:none}
.notice-timeline-icon{width:38px;height:38px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;z-index:1}
.notice-highlight{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--text-white);padding:24px;border-radius:var(--radius);margin-top:16px}

/* --- Board --- */
.board{padding:80px 0;background:var(--bg)}
.board-header{text-align:center;margin-bottom:40px}
.board-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.board-card{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--border);transition:var(--transition)}
.board-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.board-card-header{background:var(--primary);color:var(--text-white);padding:16px 20px;font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px}
.board-card-body{padding:20px}
.board-card-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.board-card-row:last-child{border-bottom:none}
.board-card-label{color:var(--text-light)}
.board-card-value{font-weight:700}
.board-card-price{color:var(--accent);font-weight:900;font-size:18px}
.board-card-footer{padding:12px 20px;background:var(--bg-alt);font-size:12px;color:var(--text-light);text-align:right}
.board-more{text-align:center;margin-top:32px}
.board-update{text-align:center;margin-top:16px;font-size:13px;color:var(--text-light)}
.board-update-icon{margin-right:4px}
.board-update-note{font-size:12px;color:var(--text-light);text-align:center;margin-top:8px}

/* --- Reviews --- */
.reviews{padding:80px 0;background:var(--bg-alt)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:var(--bg);border-radius:var(--radius);padding:32px 24px;box-shadow:var(--shadow);border:1px solid var(--border)}
.review-stars{color:var(--accent);font-size:18px;margin-bottom:12px}
.review-text{font-size:14px;line-height:1.8;color:var(--text);margin-bottom:16px}
.review-author{display:flex;align-items:center;gap:12px}
.review-name{font-size:14px;font-weight:700}
.review-product{font-size:12px;color:var(--text-light)}

/* --- FAQ --- */
.faq{padding:80px 0;background:var(--bg)}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;background:var(--bg)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;font-weight:700;font-size:15px;transition:var(--transition)}
.faq-question:hover{background:var(--bg-alt)}
.faq-toggle{font-size:20px;transition:transform .3s ease;color:var(--accent);flex-shrink:0;margin-left:16px}
.faq-item.active .faq-toggle{transform:rotate(45deg)}
.faq-answer{padding:0 24px;max-height:0;overflow:hidden;transition:all .3s ease;font-size:14px;line-height:1.8;color:var(--text-light)}
.faq-item.active .faq-answer{padding:0 24px 20px;max-height:500px}

/* --- Contact --- */
.contact{padding:80px 0;background:var(--bg-alt)}
.contact-wrapper{display:grid;grid-template-columns:1fr 360px;gap:40px;max-width:var(--container);margin:0 auto;padding:0 20px}
.contact-form{background:var(--bg);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow)}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:14px;font-weight:700;margin-bottom:8px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit;transition:var(--transition);background:var(--bg)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,164,92,.15)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.required{color:#dc2626;font-size:12px;margin-left:4px}
.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}
.checkbox-label input{width:auto}
.privacy-link{color:var(--accent);text-decoration:underline}
.form-note{font-size:12px;color:var(--text-light);margin-top:16px}
.contact-side{display:flex;flex-direction:column;gap:20px}
.contact-card{background:var(--bg);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--border)}
.contact-phone{font-size:24px;font-weight:900;color:var(--primary)}

/* --- Footer --- */
.footer{background:var(--primary-dark);color:rgba(255,255,255,.7);padding:60px 0 0}
.footer-grid{max-width:var(--container);margin:0 auto;padding:0 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{font-size:20px;font-weight:700;color:var(--text-white);margin-bottom:16px}
.footer-col h4{font-size:14px;font-weight:700;color:var(--text-white);margin-bottom:16px}
.footer-col a{display:block;font-size:13px;padding:4px 0;transition:var(--transition)}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px;text-align:center;font-size:12px}
.footer-disclaimer{max-width:var(--container);margin:0 auto 24px;padding:0 20px;font-size:11px;opacity:.5;line-height:1.8}

/* --- Fixed CTA --- */
.fixed-cta{position:fixed;bottom:0;left:0;width:100%;background:rgba(26,42,74,.98);backdrop-filter:blur(10px);padding:12px 0;z-index:999;transform:translateY(100%);transition:transform .3s ease;border-top:2px solid var(--accent)}
.fixed-cta.visible{transform:translateY(0)}
.fixed-cta-inner{max-width:var(--container);margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}
.fixed-cta-text{color:var(--text-white);font-weight:700;font-size:15px}
.fixed-cta-buttons{display:flex;gap:12px}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1024px){
  .nav{display:none}
  .hamburger{display:flex}
  .hero-large{font-size:36px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .problems-grid{grid-template-columns:repeat(2,1fr)}
  .reasons-grid{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .flow-grid{grid-template-columns:repeat(2,1fr)}
  .flow-arrow{display:none}
  .board-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .contact-wrapper{grid-template-columns:1fr}
}
@media(max-width:768px){
  .hero{min-height:auto;padding:100px 0 60px}
  .hero-large{font-size:28px}
  .hero-points{flex-direction:column;align-items:center;gap:12px}
  .hero-cta{flex-direction:column;align-items:center}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .problems-grid{grid-template-columns:1fr}
  .reasons-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:1fr}
  .client-grid{grid-template-columns:1fr}
  .flow-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section-title{font-size:24px}
  .fixed-cta-inner{flex-direction:column;gap:10px;text-align:center}
}
@media(max-width:480px){
  .hero-large{font-size:24px}
  .hero-sub{font-size:15px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stat-number{font-size:28px}
  .section-title{font-size:22px}
  .btn-lg{padding:14px 28px;font-size:16px}
  .contact-form{padding:24px}
  .price-tabs{gap:4px}
  .price-tab{padding:8px 16px;font-size:13px}
}

/* --- Price Groups (Card Layout) --- */
.price-groups {
    display: grid;
    gap: 24px;
}

.price-group {
    background: var(--bg);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    overflow: hidden;
    transition: var(--transition);
}

.price-group:hover {
    box-shadow: var(--shadow-lg);
    border-color: rgba(26,42,74,.3);
}

.price-group-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 20px;
    background: var(--primary);
    color: var(--text-white);
    font-weight: 700;
}

.price-group-header h3 {
    font-size: 0.95rem;
    margin: 0;
    font-weight: 700;
    color: inherit;
}

.price-group-icon {
    font-size: 1.2rem;
}

.price-group-items {
    padding: 0;
}

.price-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    transition: background 0.2s ease;
}

.price-row:last-child {
    border-bottom: none;
}

.price-row:hover {
    background: rgba(26,42,74,.04);
}

.price-model {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text);
}

.price-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
}

.price-value.price-high {
    color: var(--accent);
    font-size: 1.1rem;
    font-weight: 800;
}

/* Zebra striping */
.price-row:nth-child(even) {
    background: var(--bg-alt);
}

.price-row:nth-child(even):hover {
    background: rgba(26,42,74,.06);
}

/* Responsive */
@media (max-width: 768px) {
    .price-group-header {
        padding: 12px 16px;
    }
    .price-row {
        padding: 10px 16px;
    }
    .price-model {
        font-size: 0.82rem;
    }
    .price-value {
        font-size: 0.9rem;
    }
}

@media (max-width: 480px) {
    .price-row {
        padding: 10px 12px;
    }
    .price-model {
        font-size: 0.78rem;
        flex: 1;
        margin-right: 8px;
    }
}

/* --- Fixes: Notice, Board animation, FAQ always-open --- */

/* Fix 1: Notice items should stack vertically, not flex row */
.notice-item { display: block !important; }
.notice-item h3 { margin-bottom: 8px; }
.notice-item p { margin-bottom: 8px; }
.notice-item-primary { display: block !important; }

/* Fix 2: Board slideUp animation */
@keyframes slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Fix 3: FAQ answers always visible */
.faq-answer {
    max-height: none !important;
    overflow: visible !important;
    padding: 0 24px 20px !important;
}
.faq-toggle { display: none !important; }
.faq-question { cursor: default !important; }
.faq-question:hover { background: transparent !important; }

/* Fix notice-highlight: should be inline badge, not full block */
.notice-highlight {
    display: inline-block !important;
    padding: 2px 12px !important;
    margin-top: 0 !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    border-radius: 4px !important;
}

/* Fix: Footer padding for fixed CTA bar */
.footer { padding-bottom: 100px !important; }

/* --- Trust Elements --- */
.hero-trust {
    display: flex;
    justify-content: center;
    gap: 24px;
    margin-top: 16px;
    flex-wrap: wrap;
}
.hero-trust span {
    font-size: 0.8rem;
    opacity: 0.7;
    display: flex;
    align-items: center;
    gap: 4px;
}
.footer-trust {
    margin-top: 12px;
    opacity: 0.6;
}
.footer-trust p {
    margin-bottom: 2px;
}
@media (max-width: 480px) {
    .hero-trust { gap: 12px; }
    .hero-trust span { font-size: 0.75rem; }
}

/* --- Nav CTA Outline Button (よくある質問) --- */
.nav-cta-outline {
    border: 2px solid currentColor !important;
    border-radius: 20px !important;
    padding: 6px 16px !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
}
.nav-cta-outline:hover {
    opacity: 0.8;
}

/* --- Sister Site Banner --- */
.sister-site-banner {
    padding: 16px 0;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
}
.sister-link {
    display: block;
    text-decoration: none;
    color: inherit;
}
.sister-link-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    transition: all 0.3s ease;
}
.sister-link-inner:hover {
    background: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.25);
    transform: translateX(4px);
}
.sister-link-text {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    color: #fff;
}
.sister-label {
    background: #c8a45c;
    color: #1a1a2e;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 700;
}
.sister-link-text strong {
    font-size: 1rem;
    color: #fff;
}
.sister-desc {
    font-size: 0.8rem;
    opacity: 0.7;
    color: #fff;
}
.sister-arrow {
    font-size: 1.5rem;
    color: #c8a45c;
    flex-shrink: 0;
}
@media (max-width: 768px) {
    .sister-link-text { flex-direction: column; align-items: flex-start; gap: 6px; }
    .sister-link-inner { padding: 14px 16px; }
}

/* --- Nav Sister Site Link --- */
.nav-sister {
    background: linear-gradient(135deg, #c8a45c 0%, #b08d3e 100%) !important;
    color: #1a1a2e !important;
    padding: 6px 14px !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    font-size: 0.85rem !important;
}
.nav-sister:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}


/* --- 2-Row Header --- */
.header { padding: 0; }
.header-inner { flex-direction: column; align-items: stretch; height: auto; padding: 0; }
.header-row1 { display: flex; justify-content: space-between; align-items: center; padding: 10px 20px; border-bottom: 1px solid rgba(0,0,0,0.06); min-height: 56px; }
.header-row2 { padding: 8px 20px; }
.header-row2 .nav ul { justify-content: center; gap: 4px; flex-wrap: wrap; }
.header-utility { display: flex; align-items: center; gap: 12px; font-size: 0.82rem; }
.header-utility a { color: inherit; }
.header-utility .util-info { opacity: 0.7; font-size: 0.75rem; }
.header-utility .util-tel { font-weight: 700; }
@media (max-width: 768px) {
    .header-row2 { display: none; }
    .header-row1 { min-height: 60px; }
}

/* --- Header: horizontal single row override --- */
.header-inner {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 70px !important;
    padding: 0 20px !important;
    flex-wrap: nowrap !important;
    gap: 16px;
}
.header-row1 {
    padding: 0 !important;
    border-bottom: none !important;
    min-height: auto !important;
    display: flex;
    align-items: center;
    gap: 16px;
    flex: 0 0 auto;
}
.header-row2 {
    padding: 0 !important;
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-end;
    overflow-x: auto;
}
.header-row2 .nav ul {
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 2px !important;
}
.header-row2 .nav a {
    padding: 6px 10px !important;
    font-size: 0.82rem !important;
    white-space: nowrap;
}
.header-utility {
    display: flex !important;
    align-items: center;
    gap: 10px;
    font-size: 0.8rem;
    white-space: nowrap;
}
.header-utility .util-info {
    display: none;
}
@media (max-width: 1100px) {
    .header-utility .util-info { display: none; }
    .header-row2 .nav a { padding: 6px 8px !important; font-size: 0.78rem !important; }
}
@media (max-width: 900px) {
    .header-row2 { display: none !important; }
}
@media (max-width: 768px) {
    .header-inner { padding: 0 16px !important; }
    .header-utility a:not(.nav-cta):not(.nav-cta-outline) { display: none; }
}

/* --- Header: fit all nav items in one row --- */
.header-inner {
    gap: 8px !important;
    padding: 0 12px !important;
}
.logo a {
    font-size: 0.95rem !important;
}
.logo-icon {
    font-size: 1.3rem !important;
}
.header-row2 {
    overflow: visible !important;
    flex: 1 1 auto;
    min-width: 0;
}
.header-row2 .nav ul {
    gap: 0 !important;
    flex-wrap: nowrap !important;
    display: flex;
    justify-content: flex-end;
}
.header-row2 .nav a {
    padding: 6px 8px !important;
    font-size: 0.75rem !important;
    white-space: nowrap;
    letter-spacing: -0.01em;
}
.header-row2 .nav .nav-sister {
    padding: 4px 10px !important;
    font-size: 0.72rem !important;
    margin-left: 4px;
}
.header-utility {
    gap: 4px !important;
    flex-shrink: 0;
    color: rgba(255,255,255,.9);
}
.header-utility .util-info {
    display: none !important;
}
.header-utility a.nav-cta,
.header-utility a.nav-cta-outline {
    padding: 5px 10px !important;
    font-size: 0.72rem !important;
}
.header-utility a:not(.nav-cta):not(.nav-cta-outline) {
    font-size: 0.7rem !important;
}

/* At medium widths, remove util mail link but keep nav visible */
@media (max-width: 1280px) {
    .header-utility a.util-tel,
    .header-utility a[href^="mailto:"] {
        display: none !important;
    }
    .header-row2 .nav a {
        padding: 6px 6px !important;
        font-size: 0.72rem !important;
    }
    .logo a {
        font-size: 0.9rem !important;
    }
}

/* Narrower: reduce gap further */
@media (max-width: 1100px) {
    .header-row2 .nav a {
        padding: 5px 5px !important;
        font-size: 0.7rem !important;
    }
    .header-row2 .nav .nav-sister {
        padding: 4px 8px !important;
        font-size: 0.68rem !important;
    }
}

/* Smaller screens: switch to hamburger */
@media (max-width: 900px) {
    .header-row2 { display: none !important; }
    .header-utility .util-info { display: none !important; }
}

/* --- 許認可・資格バー（法人安心） --- */
.license-bar{background:var(--bg-alt);padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.license-bar-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 28px;text-align:center}
.license-bar-lead{font-size:1.05rem;font-weight:700;color:var(--primary);margin:0;line-height:1.7}
.license-badges{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.license-badge{background:#fff;border:1px solid var(--border);border-radius:50px;padding:6px 16px;font-size:.85rem;font-weight:700;color:var(--primary);white-space:nowrap}
@media(max-width:600px){.license-bar-lead{font-size:.95rem}}
