/*
Theme Name: もぐルート
Theme URI: https://mogu-route.com/
Description: もぐルート - 飲食店特化の集客支援プラットフォーム
Version: 2.0.0
Author: もぐルート
*/

/* ==========================================================================
   Design Tokens
   ========================================================================== */
:root {
    --c-primary:      #E8521A;
    --c-primary-dk:   #C4410D;
    --c-primary-lt:   #FEF0EB;
    --c-dark:         #111111;
    --c-dark2:        #1C1C1C;
    --c-dark3:        #2D2D2D;
    --c-gold:         #F5B731;
    --c-blue:         #2563EB;
    --c-navy:         #0F172A;
    --c-success:      #16A34A;
    --c-text:         #1A1A1A;
    --c-text-sub:     #52525B;
    --c-text-muted:   #A1A1AA;
    --c-border:       #E4E4E7;
    --c-border-lt:    #F4F4F5;
    --c-bg:           #FAFAF9;
    --c-surface:      #FFFFFF;

    --font-sans:    'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', sans-serif;
    --font-display: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;

    --r-sm:   4px;
    --r-md:   8px;
    --r-lg:   16px;
    --r-xl:   24px;
    --r-2xl:  32px;
    --r-full: 9999px;

    --sh-sm:  0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
    --sh-md:  0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
    --sh-lg:  0 12px 40px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.04);

    --dur:  .2s;
    --ease: cubic-bezier(.4,0,.2,1);

    --inner:  1120px;
    --pad:    clamp(20px, 5vw, 48px);
    --bnav-h: 64px;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--font-sans);
    color: var(--c-text);
    background: var(--c-bg);
    line-height: 1.75;
    padding-bottom: var(--bnav-h);
    -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { opacity: .8; }
:focus-visible { outline: 2px solid var(--c-primary); outline-offset: 3px; border-radius: 3px; }
ul, ol { list-style: none; }
button { cursor: pointer; font-family: inherit; }

.inner { max-width: var(--inner); margin: 0 auto; padding: 0 var(--pad); }
.sec { padding: clamp(64px, 10vw, 112px) 0; }

.skip-link {
    position: absolute; top: -100px; left: 16px; z-index: 9999;
    background: var(--c-primary); color: #fff;
    padding: 10px 20px; border-radius: var(--r-md); font-weight: 700; transition: top .2s;
}
.skip-link:focus { top: 8px; }

/* ==========================================================================
   Typography Helpers
   ========================================================================== */
.label-tag {
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--c-primary);
    display: block;
    margin-bottom: 12px;
}
.sec-heading {
    font-size: clamp(1.625rem, 3.5vw, 2.25rem);
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: -.03em;
    color: var(--c-dark);
    margin-bottom: 14px;
}
.sec-sub {
    font-size: 1rem;
    color: var(--c-text-sub);
    line-height: 1.8;
    margin-bottom: 56px;
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn-primary, .btn-dark, .btn-outline, .btn-outline-white,
.btn-submit, .btn-copy, .btn-booking {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 13px 30px; border-radius: var(--r-full);
    font-size: .9375rem; font-weight: 700;
    border: 2px solid transparent;
    transition: background var(--dur) var(--ease),
                border-color var(--dur) var(--ease),
                transform var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease);
    cursor: pointer; text-decoration: none; white-space: nowrap; line-height: 1.4;
    letter-spacing: .01em;
}
.btn-primary {
    background: var(--c-primary); color: #fff; border-color: var(--c-primary);
}
.btn-primary:hover {
    background: var(--c-primary-dk); border-color: var(--c-primary-dk);
    transform: translateY(-1px); box-shadow: 0 6px 20px rgba(232,82,26,.3); opacity: 1;
}
.btn-dark {
    background: var(--c-dark); color: #fff; border-color: var(--c-dark);
}
.btn-dark:hover {
    background: var(--c-dark3);
    transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,0,0,.25); opacity: 1;
}
.btn-outline {
    background: transparent; color: var(--c-primary); border-color: var(--c-primary);
}
.btn-outline:hover { background: var(--c-primary); color: #fff; opacity: 1; }

.btn-outline-white {
    background: transparent; color: rgba(255,255,255,.9);
    border: 2px solid rgba(255,255,255,.4);
    padding: 13px 30px; border-radius: var(--r-full);
    font-size: .9375rem; font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center;
    transition: all var(--dur) var(--ease); cursor: pointer; text-decoration: none;
}
.btn-outline-white:hover { border-color: rgba(255,255,255,.8); background: rgba(255,255,255,.1); opacity: 1; }

.btn-lg { padding: 16px 40px; font-size: 1rem; }
.btn-sm { padding: 9px 20px; font-size: .8125rem; }

.btn-submit {
    background: var(--c-primary); color: #fff; border: none;
    width: 100%; padding: 15px; border-radius: var(--r-md);
}
.btn-submit:hover { background: var(--c-primary-dk); }
.btn-copy, .btn-copy-code, .btn-copy-template {
    background: var(--c-dark3); color: #fff; border: none;
    padding: 8px 18px; border-radius: var(--r-sm); font-size: .875rem; cursor: pointer;
}
.btn-booking {
    background: var(--c-success); color: #fff; border: 2px solid var(--c-success);
    padding: 15px 40px; border-radius: var(--r-full);
    font-size: 1rem; font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center; width: 100%;
}
.btn-search {
    background: var(--c-primary); color: #fff; border: none;
    padding: 12px 24px; border-radius: var(--r-full);
    font-weight: 700; font-size: .9375rem; cursor: pointer;
}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header {
    position: sticky; top: 0; z-index: 200;
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--c-border);
}
.header-inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 72px; gap: 24px;
}
.site-logo a { display: flex; text-decoration: none; }
.logo-lockup { display: flex; align-items: center; gap: 10px; }
.logo-icon { display: flex; align-items: center; flex-shrink: 0; }
.logo-text {
    font-size: 1.25rem; font-weight: 900;
    color: var(--c-dark); letter-spacing: -.03em;
}

.nav-toggle {
    display: none; flex-direction: column; gap: 5px;
    background: none; border: none; padding: 8px; cursor: pointer;
}
.nav-toggle span {
    display: block; width: 22px; height: 1.5px;
    background: var(--c-dark); border-radius: 2px; transition: var(--dur) var(--ease);
}

.nav-list { display: flex; align-items: center; gap: 2px; }
.nav-list a {
    padding: 8px 14px; border-radius: var(--r-full);
    font-size: .875rem; font-weight: 500; color: var(--c-text-sub);
    transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
    white-space: nowrap;
}
.nav-list a:hover { background: var(--c-bg); color: var(--c-text); opacity: 1; }
.nav-btn {
    background: var(--c-primary) !important;
    color: #fff !important;
    font-weight: 700 !important;
    padding: 9px 20px !important;
    border-radius: var(--r-full) !important;
}
.nav-btn:hover { background: var(--c-primary-dk) !important; opacity: 1 !important; }

@media (max-width: 768px) {
    .nav-toggle { display: flex; }
    .header-nav {
        display: none; position: absolute;
        top: 72px; left: 0; right: 0;
        background: #fff; border-bottom: 1px solid var(--c-border);
        padding: 16px 20px; z-index: 199; box-shadow: var(--sh-md);
    }
    .header-nav.is-open { display: block; }
    .nav-list { flex-direction: column; align-items: stretch; gap: 2px; }
    .nav-list a { padding: 13px 16px; border-radius: var(--r-md); }
}

/* ==========================================================================
   Bottom Nav (Mobile)
   ========================================================================== */
.bottom-nav {
    display: none; position: fixed; bottom: 0; left: 0; right: 0;
    height: var(--bnav-h); background: #fff;
    border-top: 1px solid var(--c-border); z-index: 300;
}
.bottom-nav-item {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    flex: 1; gap: 3px; padding: 6px 4px;
    color: var(--c-text-muted); font-size: .5625rem; font-weight: 500;
    transition: color var(--dur) var(--ease); text-decoration: none;
}
.bottom-nav-item svg { stroke: currentColor; }
.bottom-nav-item.is-active, .bottom-nav-item:hover { color: var(--c-primary); opacity: 1; }
.bottom-nav-label { line-height: 1.2; }
@media (max-width: 768px) { .bottom-nav { display: flex; } }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero {
    background: var(--c-dark);
    padding: clamp(72px, 14vw, 136px) 0;
    position: relative; overflow: hidden;
}
.hero::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse 70% 50% at 100% 50%, rgba(232,82,26,.15) 0%, transparent 65%);
    pointer-events: none;
}
.hero-inner {
    position: relative;
    display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.hero-label {
    font-size: .6875rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    color: var(--c-gold); display: block; margin-bottom: 20px;
}
.hero-heading {
    font-size: clamp(2.25rem, 6vw, 4rem);
    font-weight: 900; line-height: 1.12; letter-spacing: -.04em;
    color: #fff; margin-bottom: 24px;
}
.hero-body {
    font-size: clamp(.9375rem, 1.8vw, 1.0625rem);
    color: rgba(255,255,255,.68); line-height: 1.9;
    margin-bottom: 36px; max-width: 480px;
}
.hero-body strong { color: rgba(255,255,255,.92); font-weight: 700; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-side { display: flex; align-items: center; }
.hero-stats {
    display: flex; flex-direction: column; gap: 0;
    background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--r-xl); overflow: hidden; min-width: 200px;
}
.hero-stat {
    padding: 20px 28px; display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
}
.hero-stat + .hero-stat { border-top: 1px solid rgba(255,255,255,.07); }
.hero-stat-num { font-size: 1.875rem; font-weight: 900; color: var(--c-gold); letter-spacing: -.04em; line-height: 1; }
.hero-stat-unit { font-size: .75rem; color: rgba(255,255,255,.4); }
.hero-stat-label { font-size: .6875rem; color: rgba(255,255,255,.4); letter-spacing: .05em; margin-top: 4px; }
.hero-stat-divider { display: none; }

@media (max-width: 768px) {
    .hero-inner { grid-template-columns: 1fr; }
    .hero-side { display: none; }
    .hero-actions { flex-direction: column; }
    .hero-actions .btn-primary, .hero-actions .btn-outline-white { width: 100%; justify-content: center; }
}

/* ==========================================================================
   About
   ========================================================================== */
.about { background: var(--c-surface); }
.about-inner {
    display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start;
}
.about-desc { font-size: .9375rem; color: var(--c-text-sub); line-height: 1.85; margin-bottom: 16px; }
.about-points { display: flex; flex-direction: column; gap: 0; }
.about-point {
    display: flex; align-items: flex-start; gap: 20px;
    padding: 24px 0; border-bottom: 1px solid var(--c-border-lt);
}
.about-point:first-child { padding-top: 0; }
.about-point:last-child { border-bottom: none; padding-bottom: 0; }
.about-point-num {
    font-size: .6875rem; font-weight: 900; letter-spacing: .08em;
    color: var(--c-primary); flex-shrink: 0; padding-top: 3px; width: 28px;
}
.about-point-body h3 { font-size: .9375rem; font-weight: 700; color: var(--c-dark); margin-bottom: 4px; }
.about-point-body p  { font-size: .875rem; color: var(--c-text-sub); line-height: 1.7; }

@media (max-width: 768px) { .about-inner { grid-template-columns: 1fr; gap: 40px; } }

/* ==========================================================================
   Services
   ========================================================================== */
.services { background: var(--c-bg); }
.svc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 8px; }
.svc-card {
    background: var(--c-surface); border-radius: var(--r-2xl);
    border: 1px solid var(--c-border); overflow: hidden;
    transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.svc-card:hover { box-shadow: var(--sh-lg); transform: translateY(-2px); }

.svc-card-header {
    padding: 40px 36px 32px; color: #fff; position: relative; overflow: hidden;
}
.svc-card-header--referral { background: linear-gradient(145deg, #1A0A04 0%, #2D1206 100%); }
.svc-card-header--sns      { background: linear-gradient(145deg, #04081A 0%, #0A1230 100%); }
.svc-card-header::after {
    content: ''; position: absolute;
    right: -20px; top: -20px;
    width: 160px; height: 160px;
    border-radius: 50%;
    background: rgba(255,255,255,.03);
    pointer-events: none;
}
.svc-num {
    display: block; font-size: .625rem; font-weight: 700; letter-spacing: .14em;
    color: rgba(255,255,255,.4); margin-bottom: 14px;
}
.svc-title {
    font-size: clamp(1.375rem, 2.5vw, 1.75rem);
    font-weight: 900; line-height: 1.2; margin-bottom: 14px; letter-spacing: -.03em;
}
.svc-tagline {
    font-size: .875rem; color: rgba(255,255,255,.58); line-height: 1.8;
}

.svc-card-body { padding: 28px 36px 32px; }
.svc-features { display: flex; flex-direction: column; gap: 18px; margin-bottom: 28px; }
.svc-features li {
    display: flex; align-items: flex-start; gap: 12px;
    font-size: .875rem; color: var(--c-text-sub); line-height: 1.7;
}
.svc-feature-icon { flex-shrink: 0; margin-top: 2px; }
.svc-features li strong { display: block; color: var(--c-text); font-weight: 700; margin-bottom: 2px; }
.svc-cta { width: 100%; justify-content: center; }

.account-profile {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 16px; background: var(--c-bg);
    border-radius: var(--r-lg); margin-bottom: 20px;
    border: 1px solid var(--c-border);
}
.account-profile-icon { flex-shrink: 0; }
.account-profile-info { display: flex; flex-direction: column; gap: 2px; }
.account-name { font-size: .875rem; font-weight: 700; color: var(--c-dark); }
.account-handle {
    font-size: .75rem; color: var(--c-primary);
    text-decoration: none; font-weight: 500;
    transition: opacity var(--dur) var(--ease);
}
.account-handle:hover { opacity: .7; }

@media (max-width: 768px) {
    .svc-grid { grid-template-columns: 1fr; }
    .svc-card-header { padding: 28px 24px 24px; }
    .svc-card-body { padding: 24px 24px 28px; }
}

/* ==========================================================================
   How it Works / Flow
   ========================================================================== */
.flow-sec { background: var(--c-surface); }
.flow-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr;
    gap: 0; align-items: center;
}
.flow-step {
    background: var(--c-bg); border-radius: var(--r-xl);
    padding: 32px 28px; border: 1px solid var(--c-border);
    transition: border-color var(--dur) var(--ease);
}
.flow-step:hover { border-color: var(--c-primary); }
.flow-step-num {
    display: inline-block; font-size: .625rem; font-weight: 900; letter-spacing: .1em;
    color: var(--c-primary); background: var(--c-primary-lt);
    padding: 4px 10px; border-radius: var(--r-full); margin-bottom: 14px;
}
.flow-step-title { font-size: 1rem; font-weight: 800; color: var(--c-dark); margin-bottom: 8px; }
.flow-step-desc { font-size: .8125rem; color: var(--c-text-sub); line-height: 1.75; }
.flow-arrow {
    display: flex; align-items: center; justify-content: center;
    padding: 0 16px; flex-shrink: 0;
}

@media (max-width: 768px) {
    .flow-grid { grid-template-columns: 1fr; gap: 0; }
    .flow-step { border-radius: 0; border-bottom: none; }
    .flow-step:first-child { border-radius: var(--r-xl) var(--r-xl) 0 0; }
    .flow-step:last-child  { border-radius: 0 0 var(--r-xl) var(--r-xl); border-bottom: 1px solid var(--c-border); }
    .flow-arrow { padding: 12px 0; transform: rotate(90deg); }
}

/* ==========================================================================
   CTA Section
   ========================================================================== */
.cta-sec { background: var(--c-dark); position: relative; overflow: hidden; }
.cta-sec::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse 60% 70% at 50% 50%, rgba(232,82,26,.12) 0%, transparent 70%);
    pointer-events: none;
}
.cta-inner { max-width: 680px; margin: 0 auto; position: relative; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer { background: #0A0A0A; color: rgba(255,255,255,.55); padding: 60px 0 28px; }
.footer-inner {}
.footer-grid {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 52px;
}
.footer-brand {}
.footer-logo-wrap { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.footer-logo-text {
    font-size: 1.25rem; font-weight: 900; color: #fff; letter-spacing: -.03em;
}
.footer-tagline { font-size: .8125rem; color: rgba(255,255,255,.32); line-height: 1.8; }
.footer-heading {
    font-size: .6875rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: rgba(255,255,255,.7); margin-bottom: 16px;
}
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a {
    font-size: .8125rem; color: rgba(255,255,255,.4);
    transition: color var(--dur) var(--ease); text-decoration: none;
}
.footer-links a:hover { color: rgba(255,255,255,.8); opacity: 1; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.06); padding-top: 24px; }
.footer-copy { font-size: .75rem; color: rgba(255,255,255,.22); }

/* レガシー互換 */
.footer-logo { font-size: 1.25rem; font-weight: 900; color: #fff; letter-spacing: -.03em; margin-bottom: 8px; }
.footer-tagline { font-size: .8125rem; color: rgba(255,255,255,.32); line-height: 1.8; margin-bottom: 0; }

@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } .footer-brand { grid-column: 1/-1; } }
@media (max-width: 520px)  { .footer-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Section Padding (Legacy compatibility)
   ========================================================================== */
.section-padding { padding: clamp(64px, 10vw, 112px) 0; }
.section-title {
    font-size: clamp(1.625rem, 3.5vw, 2.25rem); font-weight: 900;
    line-height: 1.2; letter-spacing: -.03em; color: var(--c-dark);
    margin-bottom: 40px; text-align: center;
}
.section-title::after {
    content: ''; display: block; width: 32px; height: 3px;
    background: var(--c-primary); border-radius: 2px; margin: 14px auto 0;
}
.section-desc { text-align: center; color: var(--c-text-sub); margin-bottom: 40px; font-size: .9375rem; }

/* ==========================================================================
   Page Hero (common)
   ========================================================================== */
.page-hero {
    background: var(--c-dark); color: #fff;
    padding: clamp(48px, 9vw, 88px) 0; text-align: center;
    position: relative; overflow: hidden;
}
.page-hero::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse 70% 50% at 50% 50%, rgba(232,82,26,.1) 0%, transparent 70%);
}
.page-hero-eyebrow { font-size: .6875rem; font-weight: 700; letter-spacing: .14em; color: var(--c-gold); margin-bottom: 12px; position: relative; }
.page-hero-title { font-size: clamp(1.75rem, 4vw, 2.75rem); font-weight: 900; margin-bottom: 12px; letter-spacing: -.04em; position: relative; }
.page-hero-desc { font-size: .9375rem; color: rgba(255,255,255,.6); position: relative; }

/* ==========================================================================
   Search / Projects
   ========================================================================== */
.search-box {
    background: var(--c-surface); border-radius: var(--r-xl);
    padding: 24px 28px; margin-bottom: 36px; border: 1px solid var(--c-border);
}
.search-kw { display: flex; gap: 10px; margin-bottom: 14px; }
.search-kw-input, .search-input-kw {
    flex: 1; padding: 12px 16px; border: 1px solid var(--c-border);
    border-radius: var(--r-full); font-size: .9375rem; font-family: inherit;
    background: var(--c-bg); transition: border-color var(--dur) var(--ease);
}
.search-kw-input:focus, .search-input-kw:focus { outline: none; border-color: var(--c-primary); }
.search-filters, .search-fields { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.search-select {
    flex: 1; min-width: 148px; padding: 10px 14px;
    border: 1px solid var(--c-border); border-radius: var(--r-full);
    font-size: .875rem; font-family: inherit; background: var(--c-bg);
    cursor: pointer; transition: border-color var(--dur) var(--ease);
}
.search-select:focus { outline: none; border-color: var(--c-primary); }
.tag-bar, .tag-filter {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding-top: 14px; border-top: 1px solid var(--c-border-lt);
}
.tag-pill, .tag-btn {
    padding: 5px 14px; border-radius: var(--r-full);
    border: 1px solid var(--c-border); font-size: .8125rem; font-weight: 500;
    background: var(--c-surface); cursor: pointer;
    transition: all var(--dur) var(--ease); text-decoration: none; color: var(--c-text-sub);
}
.tag-pill:hover, .tag-pill.is-active,
.tag-btn:hover, .tag-btn.is-active {
    background: var(--c-primary); color: #fff; border-color: var(--c-primary); opacity: 1;
}

/* Project cards */
.project-list, .project-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(288px, 1fr)); gap: 20px;
}
.project-item {
    background: var(--c-surface); border-radius: var(--r-xl);
    overflow: hidden; border: 1px solid var(--c-border);
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.project-item:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.project-item-link { display: block; text-decoration: none; color: inherit; }
.project-thumb { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--c-bg); }
.project-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.project-item:hover .project-thumb img { transform: scale(1.03); }
.project-thumb-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: var(--c-bg); }
.project-thumb-placeholder::after { content: ''; display: block; width: 40px; height: 40px; border: 2px solid var(--c-border); border-radius: var(--r-md); }
.reward-badge, .badge-reward {
    position: absolute; top: 10px; right: 10px;
    padding: 4px 10px; border-radius: var(--r-full);
    font-size: .75rem; font-weight: 700;
    background: var(--c-primary); color: #fff;
}
.new-badge, .badge-new {
    position: absolute; top: 10px; left: 10px;
    padding: 3px 8px; border-radius: var(--r-full);
    font-size: .6875rem; font-weight: 700;
    background: var(--c-success); color: #fff;
}
.project-content { padding: 16px 18px; }
.project-meta-tags { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 8px; }
.meta-tag {
    font-size: .6875rem; padding: 2px 8px; border-radius: var(--r-full);
    border: 1px solid var(--c-border); background: var(--c-bg); color: var(--c-text-sub);
}
.area-tag  { background: #EFF6FF; border-color: #BFDBFE; color: #1D4ED8; }
.cat-tag   { background: #FAF5FF; border-color: #DDD6FE; color: #7C3AED; }
.price-tag { background: #F0FDF4; border-color: #BBF7D0; color: #15803D; }
.project-title { font-size: .9375rem; font-weight: 700; margin-bottom: 4px; line-height: 1.4; color: var(--c-dark); }
.project-catchphrase { font-size: .8125rem; color: var(--c-text-sub); margin-bottom: 12px; }
.project-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--c-border-lt); }
.project-reward-label { font-size: .6875rem; color: var(--c-text-muted); }
.project-reward-amount { font-size: 1.0625rem; font-weight: 900; color: var(--c-primary); }
.results-count { grid-column: 1/-1; font-size: .875rem; color: var(--c-text-muted); margin-bottom: 4px; }
.no-results { grid-column: 1/-1; text-align: center; padding: 56px 20px; color: var(--c-text-muted); }
.no-results p { margin-bottom: 20px; }

.project-pagination, .nav-links { margin-top: 48px; display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.page-numbers {
    padding: 8px 14px; border-radius: var(--r-md);
    border: 1px solid var(--c-border); font-size: .875rem;
    text-decoration: none; color: var(--c-text);
    transition: all var(--dur) var(--ease);
}
.page-numbers.current { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }
.page-numbers:hover { border-color: var(--c-primary); color: var(--c-primary); opacity: 1; }

@media (max-width: 640px) {
    .search-box { padding: 18px; }
    .search-filters, .search-fields { flex-direction: column; }
    .search-select { min-width: 100%; }
    .search-kw { flex-direction: column; }
    .search-kw-input, .search-kw .btn-search { width: 100%; }
}

/* ==========================================================================
   Area Grid
   ========================================================================== */
.area-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(128px, 1fr)); gap: 10px;
}
.area-card {
    background: var(--c-surface); border-radius: var(--r-lg);
    padding: 18px 12px; text-align: center;
    border: 1px solid var(--c-border);
    display: flex; flex-direction: column; gap: 4px;
    transition: all var(--dur) var(--ease); text-decoration: none; color: inherit;
}
.area-card:hover { border-color: var(--c-primary); transform: translateY(-2px); box-shadow: var(--sh-sm); opacity: 1; }
.area-icon { display: none; }
.area-name { font-weight: 700; font-size: .875rem; color: var(--c-dark); }
.area-count { font-size: .6875rem; color: var(--c-text-muted); }

/* ==========================================================================
   Detail Page
   ========================================================================== */
.detail-container, .detail-wrap { max-width: 800px; margin: 40px auto; padding: 0 var(--pad); }
.invited-banner { background: var(--c-success); color: #fff; padding: 13px 18px; border-radius: var(--r-md); font-weight: 700; text-align: center; margin-bottom: 22px; }
.detail-header { margin-bottom: 26px; }
.detail-meta, .detail-meta-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.detail-title { font-size: clamp(1.5rem, 4vw, 2rem); font-weight: 900; margin-bottom: 8px; color: var(--c-dark); letter-spacing: -.03em; }
.detail-catchphrase { font-size: 1rem; color: var(--c-text-sub); margin-bottom: 14px; }
.detail-reward { display: inline-flex; align-items: center; gap: 12px; background: var(--c-primary-lt); border: 1px solid rgba(232,82,26,.2); border-radius: var(--r-md); padding: 12px 18px; }
.reward-label { font-size: .8125rem; color: var(--c-text-muted); }
.reward-amount-large, .reward-large { font-size: 1.875rem; font-weight: 900; color: var(--c-primary); letter-spacing: -.04em; }

.detail-gallery { margin-bottom: 28px; }
.gallery-main { border-radius: var(--r-xl); overflow: hidden; margin-bottom: 8px; }
.gallery-main-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.gallery-thumbs { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.gallery-thumb { width: 100px; height: 68px; object-fit: cover; border-radius: var(--r-sm); flex-shrink: 0; cursor: pointer; border: 2px solid transparent; transition: border-color var(--dur) var(--ease); }
.gallery-thumb:hover { border-color: var(--c-primary); }

.detail-body { margin-bottom: 28px; }
.format-box { background: var(--c-bg); border-radius: var(--r-md); padding: 18px 20px; margin-bottom: 20px; border-left: 3px solid var(--c-primary); }
.format-box h2 { font-size: 1rem; font-weight: 700; margin-bottom: 8px; }
.format-box p { color: var(--c-text-sub); font-size: .9rem; }
.detail-table { width: 100%; border-collapse: collapse; margin-bottom: 20px; font-size: .9375rem; }
.detail-table th, .detail-table td { padding: 12px 16px; border-bottom: 1px solid var(--c-border-lt); text-align: left; vertical-align: top; }
.detail-table th { width: 140px; font-weight: 700; color: var(--c-text-muted); background: var(--c-bg); white-space: nowrap; font-size: .875rem; }

.detail-action { background: var(--c-surface); border-radius: var(--r-2xl); padding: 28px; box-shadow: var(--sh-md); border: 1px solid var(--c-border); margin-bottom: 36px; }
.referral-link-generator h3 { font-size: 1rem; font-weight: 700; margin-bottom: 6px; }
.ref-link-desc { font-size: .875rem; color: var(--c-text-sub); margin-bottom: 14px; }
.copy-url-area { display: flex; gap: 8px; margin-bottom: 18px; }
.copy-url-area input { flex: 1; padding: 10px 13px; border: 1px solid var(--c-border); border-radius: var(--r-sm); font-size: .875rem; background: var(--c-bg); color: var(--c-text); }

.share-buttons { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.share-label { width: 100%; font-size: .8125rem; color: var(--c-text-muted); margin-bottom: 4px; }
.share-btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 16px; border-radius: var(--r-full); font-size: .875rem; font-weight: 700; border: none; cursor: pointer; text-decoration: none; transition: all var(--dur) var(--ease); }
.share-line { background: #06C755; color: #fff; }
.share-twitter { background: #000; color: #fff; }
.share-facebook { background: #1877F2; color: #fff; }
.share-copy { background: var(--c-dark3); color: #fff; }
.share-btn:hover { opacity: .85; transform: translateY(-1px); }
.share-icon { font-size: 1rem; }

.share-template { background: var(--c-bg); border-radius: var(--r-md); padding: 14px 16px; }
.share-template-label { font-size: .75rem; color: var(--c-text-muted); margin-bottom: 8px; }
.share-template-text { font-size: .875rem; line-height: 1.6; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--r-sm); padding: 12px; margin-bottom: 8px; white-space: pre-wrap; word-break: break-all; }
.login-cta { text-align: center; }
.login-cta p { margin-bottom: 14px; }
.login-cta .btn-primary, .login-cta .btn-outline { margin: 0 5px; }
.invited-note { font-size: .75rem; color: var(--c-text-muted); text-align: center; margin-top: 8px; }

/* ==========================================================================
   My Page
   ========================================================================== */
.my-page-container, .mypage-wrap { background: var(--c-surface); border-radius: var(--r-2xl); padding: 32px; box-shadow: var(--sh-sm); margin-bottom: 20px; border: 1px solid var(--c-border); }
.my-page-header, .mypage-header { display: flex; align-items: center; gap: 14px; margin-bottom: 26px; padding-bottom: 20px; border-bottom: 1px solid var(--c-border); }
.my-page-header h2, .mypage-header h2 { font-size: 1.25rem; font-weight: 900; letter-spacing: -.03em; }
.my-page-since, .mypage-since { font-size: .75rem; color: var(--c-text-muted); margin-top: 3px; }
.my-page-section, .mypage-sec { margin-bottom: 26px; padding-bottom: 26px; border-bottom: 1px solid var(--c-border-lt); }
.my-page-section:last-child, .mypage-sec:last-child { border-bottom: none; }
.my-page-section h3, .mypage-sec h3 { font-size: .9375rem; font-weight: 700; margin-bottom: 14px; }

.stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(136px, 1fr)); gap: 12px; margin-bottom: 18px; }
.stat-card { background: var(--c-bg); border-radius: var(--r-lg); padding: 16px 14px; text-align: center; border: 1px solid var(--c-border); }
.stat-card.highlight { border-color: var(--c-primary); background: var(--c-primary-lt); }
.stat-number, .stat-num { display: block; font-size: 1.5rem; font-weight: 900; color: var(--c-primary); letter-spacing: -.04em; }
.stat-label { display: block; font-size: .6875rem; color: var(--c-text-muted); margin-top: 3px; }
.funnel-bar-wrap { margin-top: 10px; }
.funnel-label, .funnel-bar-label { font-size: .75rem; color: var(--c-text-muted); margin-bottom: 4px; }
.funnel-bar { height: 6px; background: var(--c-border); border-radius: 3px; overflow: hidden; margin-bottom: 10px; }
.funnel-fill { height: 100%; background: linear-gradient(90deg, var(--c-primary), var(--c-gold)); border-radius: 3px; transition: width .8s var(--ease); }
.ref-code-display { font-size: 2rem; font-weight: 900; font-family: monospace; letter-spacing: .3em; color: var(--c-primary); background: var(--c-bg); border: 2px dashed rgba(232,82,26,.3); border-radius: var(--r-md); padding: 16px; text-align: center; margin-bottom: 12px; }
.reward-history-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.reward-history-table th, .reward-history-table td { padding: 10px 12px; border-bottom: 1px solid var(--c-border-lt); text-align: left; }
.reward-history-table th { background: var(--c-bg); font-weight: 700; font-size: .8125rem; color: var(--c-text-muted); }
.my-page-actions, .mypage-actions { text-align: center; margin-top: 18px; }
.balance-info { font-size: 1rem; margin-bottom: 16px; padding: 12px 16px; background: var(--c-bg); border-radius: var(--r-sm); }
.balance-info strong { color: var(--c-primary); font-size: 1.25rem; font-weight: 900; }

/* ==========================================================================
   Forms
   ========================================================================== */
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: .875rem; font-weight: 700; margin-bottom: 6px; color: var(--c-dark); }
.form-group input[type="text"],
.form-group input[type="number"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
    width: 100%; padding: 12px 14px;
    border: 1px solid var(--c-border); border-radius: var(--r-md);
    font-size: .9375rem; font-family: inherit; background: var(--c-bg);
    transition: border-color var(--dur) var(--ease);
}
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--c-primary); background: var(--c-surface); }
.form-check label { display: flex; align-items: center; gap: 8px; font-weight: 400; }
.form-required { display: inline-block; background: var(--c-primary); color: #fff; font-size: .625rem; padding: 1px 6px; border-radius: 3px; margin-left: 5px; font-weight: 700; vertical-align: middle; }
.form-privacy-note { font-size: .8125rem; color: var(--c-text-muted); }
.form-privacy-note a { color: var(--c-primary); text-decoration: underline; }

.alert-success { background: #F0FDF4; border: 1px solid #86EFAC; border-radius: var(--r-sm); padding: 12px 16px; color: #166534; margin-bottom: 14px; }
.alert-error   { background: #FFF1F2; border: 1px solid #FCA5A5; border-radius: var(--r-sm); padding: 12px 16px; color: #991B1B; margin-bottom: 14px; }
.alert-info    { background: #EFF6FF; border: 1px solid #93C5FD; border-radius: var(--r-sm); padding: 12px 16px; color: #1E40AF; margin-bottom: 14px; }

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-wrap { max-width: 960px; margin: 0 auto; }
.contact-info-grid, .contact-grid { display: grid; grid-template-columns: 1fr 280px; gap: 24px; align-items: start; }
.contact-box { background: var(--c-surface); border-radius: var(--r-2xl); padding: 36px; box-shadow: var(--sh-sm); border: 1px solid var(--c-border); }
.contact-box-title { font-size: 1.125rem; font-weight: 900; margin-bottom: 22px; letter-spacing: -.03em; }
.contact-form .form-group input[type="text"],
.contact-form .form-group input[type="email"],
.contact-form .form-group input[type="tel"],
.contact-form .form-group textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--c-border); border-radius: var(--r-md); font-size: .9375rem; font-family: inherit; background: var(--c-bg); transition: border-color var(--dur) var(--ease); }
.contact-form .form-group input:focus, .contact-form .form-group textarea:focus { outline: none; border-color: var(--c-primary); background: var(--c-surface); }
.contact-info-col { display: flex; flex-direction: column; gap: 12px; }
.contact-info-card { background: var(--c-surface); border-radius: var(--r-lg); padding: 18px 20px; border: 1px solid var(--c-border); }
.contact-info-card h3 { font-size: .9375rem; font-weight: 700; margin-bottom: 5px; }
.contact-info-card p { font-size: .875rem; color: var(--c-text-sub); line-height: 1.7; }
.contact-info-card a { color: var(--c-primary); text-decoration: underline; }
.contact-thanks { text-align: center; padding: 56px 20px; background: var(--c-surface); border-radius: var(--r-2xl); box-shadow: var(--sh-sm); }
.contact-thanks-icon { font-size: 3rem; margin-bottom: 14px; color: var(--c-success); }
.contact-thanks h2 { font-size: 1.375rem; font-weight: 900; margin-bottom: 10px; letter-spacing: -.03em; }
.contact-thanks p { color: var(--c-text-sub); }
@media (max-width: 768px) { .contact-info-grid, .contact-grid { grid-template-columns: 1fr; } .contact-box { padding: 24px; } }

/* ==========================================================================
   Legal
   ========================================================================== */
.legal-container, .legal-wrap { max-width: 800px; }
.legal-intro { font-size: .9375rem; color: var(--c-text-sub); margin-bottom: 36px; padding: 16px 20px; background: var(--c-bg); border-radius: var(--r-md); border-left: 3px solid var(--c-primary); }
.legal-section, .legal-sec { margin-bottom: 36px; }
.legal-section h2, .legal-sec h2 { font-size: 1rem; font-weight: 700; color: var(--c-dark); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--c-border); }
.legal-section p, .legal-sec p { color: var(--c-text-sub); margin-bottom: 10px; line-height: 1.8; font-size: .9375rem; }
.legal-section ul, .legal-sec ul { margin: 10px 0 10px 18px; list-style: disc; }
.legal-section ul li, .legal-sec ul li { color: var(--c-text-sub); margin-bottom: 5px; font-size: .9375rem; }
.legal-footer-note, .legal-foot-note { margin-top: 40px; padding-top: 20px; border-top: 1px solid var(--c-border); font-size: .875rem; color: var(--c-text-muted); }
.legal-footer-note a, .legal-foot-note a { color: var(--c-primary); text-decoration: underline; }
.tokushoho-table { width: 100%; border-collapse: collapse; font-size: .9375rem; }
.tokushoho-table th, .tokushoho-table td { padding: 12px 16px; border-bottom: 1px solid var(--c-border-lt); text-align: left; vertical-align: top; }
.tokushoho-table th { width: 180px; font-weight: 700; background: var(--c-bg); white-space: nowrap; color: var(--c-text-muted); font-size: .875rem; }
.tokushoho-table td { color: var(--c-text); line-height: 1.7; }
@media (max-width: 600px) { .tokushoho-table, .tokushoho-table tbody, .tokushoho-table tr, .tokushoho-table th, .tokushoho-table td { display: block; } .tokushoho-table th { width: 100%; border-bottom: none; padding-bottom: 4px; } .tokushoho-table td { padding-top: 4px; } }

/* ==========================================================================
   Login
   ========================================================================== */
.login-page { min-height: calc(100vh - 72px - var(--bnav-h)); display: flex; align-items: center; justify-content: center; padding: 40px var(--pad); background: var(--c-dark); position: relative; overflow: hidden; }
.login-page::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 60% at 50% 40%, rgba(232,82,26,.12) 0%, transparent 70%); }
.login-wrap { width: 100%; max-width: 420px; position: relative; }
.login-card { background: var(--c-surface); border-radius: var(--r-2xl); padding: 40px 36px; box-shadow: var(--sh-lg); border: 1px solid var(--c-border); }
.login-logo { text-align: center; margin-bottom: 24px; }
.login-logo-link { text-decoration: none; display: inline-flex; align-items: center; gap: 10px; }
.login-logo-mark { width: 36px; height: 36px; background: var(--c-primary); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; }
.login-logo-text { font-size: 1.375rem; font-weight: 900; color: var(--c-dark); letter-spacing: -.03em; }
.login-tagline { font-size: .75rem; color: var(--c-text-muted); margin-top: 4px; text-align: center; }
.login-title { font-size: 1.25rem; font-weight: 900; text-align: center; margin-bottom: 22px; color: var(--c-dark); letter-spacing: -.03em; }
.login-page #loginform { margin: 0; padding: 0; border: none; box-shadow: none; background: none; }
.login-page #loginform p { margin-bottom: 14px; }
.login-page #loginform label { display: block; font-size: .875rem; font-weight: 700; margin-bottom: 6px; color: var(--c-dark); }
.login-page #loginform input[type="text"], .login-page #loginform input[type="password"] { width: 100%; padding: 12px 14px; border: 1px solid var(--c-border); border-radius: var(--r-md); font-size: .9375rem; font-family: inherit; background: var(--c-bg); transition: border-color var(--dur) var(--ease); box-shadow: none; }
.login-page #loginform input:focus { outline: none; border-color: var(--c-primary); background: var(--c-surface); }
.login-page #loginform .login-remember { display: flex; align-items: center; gap: 6px; font-size: .875rem; }
.login-page #loginform input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--c-primary); }
.login-page #loginform input[type="submit"] { width: 100%; padding: 14px; background: var(--c-primary); color: #fff; border: none; border-radius: var(--r-full); font-size: .9375rem; font-weight: 700; font-family: inherit; cursor: pointer; transition: background var(--dur) var(--ease); margin-top: 8px; }
.login-page #loginform input[type="submit"]:hover { background: var(--c-primary-dk); }
.login-links { display: flex; justify-content: center; gap: 16px; margin-top: 16px; font-size: .8125rem; }
.login-links a { color: var(--c-primary); text-decoration: underline; }
.login-links-sep { color: var(--c-border); }
.login-back { text-align: center; margin-top: 16px; font-size: .8125rem; color: var(--c-text-muted); }
.login-back a { color: var(--c-text-muted); text-decoration: underline; }

/* ==========================================================================
   Restaurant / Dashboard / Other
   ========================================================================== */
.restaurant-merit-grid, .merit-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.merit-card { background: var(--c-surface); border-radius: var(--r-xl); padding: 24px 20px; text-align: center; box-shadow: var(--sh-sm); border: 1px solid var(--c-border); }
.merit-icon { font-size: 0; width: 36px; height: 36px; background: var(--c-primary-lt); border-radius: var(--r-md); margin: 0 auto 12px; }
.merit-card h3 { font-size: .9375rem; font-weight: 700; margin-bottom: 7px; }
.merit-card p { font-size: .875rem; color: var(--c-text-sub); }
.restaurant-dashboard { padding: 24px; background: var(--c-surface); border-radius: var(--r-xl); box-shadow: var(--sh-sm); border: 1px solid var(--c-border); }
.restaurant-dashboard h2 { font-size: 1.125rem; font-weight: 900; margin-bottom: 8px; letter-spacing: -.03em; }
.restaurant-project-list { display: flex; flex-direction: column; gap: 12px; margin-top: 16px; }
.restaurant-project-card { background: var(--c-bg); border-radius: var(--r-md); padding: 16px 18px; border: 1px solid var(--c-border); }
.restaurant-project-card h3 { font-size: .9375rem; font-weight: 700; margin-bottom: 8px; }
.restaurant-stats { display: flex; gap: 16px; font-size: .875rem; color: var(--c-text-sub); margin-bottom: 10px; }
.login-required { text-align: center; padding: 56px 20px; background: var(--c-surface); border-radius: var(--r-xl); box-shadow: var(--sh-sm); border: 1px solid var(--c-border); }
.login-required a { color: var(--c-primary); font-weight: 700; text-decoration: underline; }
.related-terms { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; padding: 13px 16px; background: var(--c-surface); border-radius: var(--r-md); border: 1px solid var(--c-border); }
.related-terms-label { font-size: .8125rem; font-weight: 700; color: var(--c-text-muted); white-space: nowrap; }
.step-detail-list { display: flex; flex-direction: column; gap: 20px; }
.step-detail-item { display: flex; align-items: flex-start; gap: 20px; background: var(--c-surface); border-radius: var(--r-xl); padding: 24px; border: 1px solid var(--c-border); }
.step-detail-num { font-size: .625rem; font-weight: 900; color: var(--c-primary); white-space: nowrap; padding-top: 4px; letter-spacing: .1em; }
.step-detail-content { flex: 1; }
.step-detail-content h3 { font-size: 1rem; font-weight: 700; margin-bottom: 6px; }
.step-detail-content p { color: var(--c-text-sub); font-size: .875rem; }
.step-detail-icon { font-size: 0; width: 32px; height: 32px; flex-shrink: 0; }
.how-faq-list { display: flex; flex-direction: column; gap: 12px; }
.how-faq-item { background: var(--c-surface); border-radius: var(--r-lg); padding: 16px 18px; border: 1px solid var(--c-border); }
.how-faq-item h4 { font-size: .875rem; font-weight: 700; margin-bottom: 6px; color: var(--c-primary); }
.how-faq-item p { font-size: .875rem; color: var(--c-text-sub); }
.faq-inner { max-width: 760px; margin: 0 auto; }
.faq-nav { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 36px; justify-content: center; }
.faq-nav-btn { padding: 7px 16px; border-radius: var(--r-full); border: 1px solid var(--c-border); color: var(--c-text-sub); font-size: .8125rem; font-weight: 500; text-decoration: none; transition: all var(--dur) var(--ease); }
.faq-nav-btn:hover { border-color: var(--c-primary); color: var(--c-primary); opacity: 1; }
.faq-group { margin-bottom: 44px; }
.faq-group-title { font-size: 1.0625rem; font-weight: 800; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid var(--c-border); letter-spacing: -.03em; }
.faq-item { border-bottom: 1px solid var(--c-border-lt); }
.faq-question { width: 100%; text-align: left; background: none; border: none; padding: 18px 0; font-size: .9375rem; font-weight: 700; font-family: inherit; display: flex; justify-content: space-between; align-items: center; gap: 12px; cursor: pointer; transition: color var(--dur) var(--ease); color: var(--c-dark); }
.faq-question:hover, .faq-question[aria-expanded="true"] { color: var(--c-primary); }
.faq-icon { font-size: 1rem; flex-shrink: 0; transition: transform var(--dur) var(--ease); }
.faq-question[aria-expanded="true"] .faq-icon { transform: rotate(45deg); }
.faq-answer { display: none; padding: 0 0 18px; color: var(--c-text-sub); font-size: .9rem; line-height: 1.8; }
.faq-answer.is-open { display: block; }
.faq-contact-cta { text-align: center; padding: 36px 0; }
.faq-contact-cta p { margin-bottom: 14px; color: var(--c-text-sub); }

/* ==========================================================================
   Responsive Misc
   ========================================================================== */
@media (max-width: 768px) {
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .detail-table th { width: 90px; font-size: .8125rem; }
    .copy-url-area { flex-direction: column; }
    .share-btn { flex: 1 1 calc(50% - 4px); justify-content: center; }
    .my-page-container, .mypage-wrap { padding: 20px; }
}
@media (max-width: 480px) {
    .login-card { padding: 28px 20px; }
    .footer-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   HOKU MESHI — SNS Page Styles
   ========================================================================== */

/* カラー変数 */
:root {
    --hm-dark:    #0a1a2e;
    --hm-dark2:   #1a3a5c;
    --hm-gold:    #e8b84b;
    --hm-gold-lt: #f5d06a;
    --hm-blue:    #a0c4e8;
    --hm-red:     #d94040;
}

/* Hero */
.hm-hero {
    background: var(--hm-dark);
    padding: clamp(64px,12vw,112px) 0;
    position: relative; overflow: hidden;
}
.hm-hero-bg {
    position: absolute; inset: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 50% 60% at 20% 50%, rgba(232,184,75,.07) 0%, transparent 65%),
        radial-gradient(ellipse 60% 70% at 80% 30%, rgba(26,58,92,.6) 0%, transparent 65%);
}
.hm-hero-inner {
    position: relative;
    display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.hm-eyebrow {
    font-size: .6875rem; font-weight: 700; letter-spacing: .14em;
    color: rgba(255,255,255,.35); display: block; margin-bottom: 16px;
}
.hm-hero-heading {
    font-size: clamp(2rem,5.5vw,3.5rem); font-weight: 900;
    line-height: 1.12; letter-spacing: -.04em; color: #fff; margin-bottom: 20px;
}
.hm-hero-heading span { color: var(--hm-gold); }
.hm-hero-desc {
    font-size: 1rem; color: rgba(255,255,255,.62); line-height: 1.9;
    margin-bottom: 32px; max-width: 480px;
}
.hm-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hm-btn-ghost {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 13px 28px; border-radius: var(--r-full);
    border: 1px solid rgba(232,184,75,.4); color: rgba(232,184,75,.85);
    font-size: .9375rem; font-weight: 700; text-decoration: none;
    transition: all var(--dur) var(--ease);
}
.hm-btn-ghost:hover { border-color: var(--hm-gold); color: var(--hm-gold); background: rgba(232,184,75,.08); opacity: 1; }

/* Hero Logo */
.hm-hero-logo-wrap { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.hm-logo-ring {
    width: 200px; height: 200px; border-radius: 50%;
    box-shadow: 0 0 60px rgba(232,184,75,.25), 0 0 0 3px rgba(232,184,75,.2);
    overflow: hidden; flex-shrink: 0;
}
.hm-logo-img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.hm-logo-meta { text-align: center; }
.hm-logo-name { display: block; font-size: .875rem; font-weight: 700; color: rgba(255,255,255,.8); margin-bottom: 4px; }
.hm-logo-handle {
    font-size: .8125rem; color: var(--hm-blue); text-decoration: none;
    transition: color var(--dur) var(--ease);
}
.hm-logo-handle:hover { color: #fff; opacity: 1; }

/* Account Card */
.hm-account-card {
    display: flex; align-items: center; gap: 40px;
    background: var(--hm-dark); border-radius: var(--r-2xl); padding: 40px;
    margin-bottom: 40px; border: 1px solid rgba(232,184,75,.15);
    box-shadow: 0 8px 40px rgba(10,26,46,.15);
}
.hm-account-left { flex-shrink: 0; }
.hm-account-logo {
    width: 120px; height: 120px; border-radius: 50%;
    box-shadow: 0 0 40px rgba(232,184,75,.3);
}
.hm-account-right { flex: 1; }
.hm-account-platform { font-size: .6875rem; font-weight: 700; letter-spacing: .12em; color: rgba(255,255,255,.3); margin-bottom: 6px; }
.hm-account-name { font-size: 1.375rem; font-weight: 900; color: #fff; margin-bottom: 4px; letter-spacing: -.02em; }
.hm-account-handle {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .875rem; color: var(--hm-blue); text-decoration: none; margin-bottom: 14px;
    transition: color var(--dur) var(--ease);
}
.hm-account-handle:hover { color: #fff; opacity: 1; }
.hm-account-desc { font-size: .875rem; color: rgba(255,255,255,.55); line-height: 1.8; margin-bottom: 20px; }

/* Points */
.hm-points { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.hm-point {
    background: var(--c-bg); border-radius: var(--r-xl); padding: 24px 20px;
    border: 1px solid var(--c-border);
    transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.hm-point:hover { border-color: var(--hm-dark); transform: translateY(-2px); }
.hm-point-icon {
    width: 40px; height: 40px; border-radius: var(--r-md);
    display: flex; align-items: center; justify-content: center; margin-bottom: 12px;
}
.hm-point h3 { font-size: .9375rem; font-weight: 800; color: var(--c-dark); margin-bottom: 7px; }
.hm-point p  { font-size: .8125rem; color: var(--c-text-sub); line-height: 1.75; }

/* Service Items */
.hm-svc-item {
    background: var(--c-surface); border-radius: var(--r-xl); padding: 22px 20px;
    border: 1px solid var(--c-border);
    display: flex; gap: 14px; align-items: flex-start;
    transition: border-color var(--dur) var(--ease);
}
.hm-svc-item:hover { border-color: var(--hm-dark); }
.hm-svc-num {
    width: 32px; height: 32px; border-radius: var(--r-md);
    background: var(--hm-dark); color: var(--hm-gold);
    font-size: .625rem; font-weight: 900; letter-spacing: .05em;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.hm-svc-title { font-size: .9375rem; font-weight: 700; color: var(--c-dark); margin-bottom: 4px; }
.hm-svc-desc  { font-size: .8125rem; color: var(--c-text-sub); line-height: 1.7; }

/* FAQ */
.hm-faq-item { border-top: 1px solid var(--c-border); }
.hm-faq-item:first-child { border-top: none; }
.hm-faq-q {
    width: 100%; text-align: left; background: none; border: none;
    padding: 20px 24px; font-size: .9375rem; font-weight: 700; font-family: inherit;
    color: var(--c-dark); display: flex; justify-content: space-between; align-items: center;
    gap: 12px; cursor: pointer; transition: color var(--dur) var(--ease);
}
.hm-faq-q:hover { color: var(--hm-dark); }
.hm-faq-a { display: none; padding: 0 24px 20px; }
.hm-faq-a p { font-size: .875rem; color: var(--c-text-sub); line-height: 1.8; }

/* CTA */
.hm-cta { background: var(--hm-dark); position: relative; overflow: hidden; }
.hm-cta-bg {
    position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(232,184,75,.06) 0%, transparent 70%);
}
.hm-cta-logo {
    width: 80px; height: 80px; border-radius: 50%;
    margin: 0 auto 24px;
    box-shadow: 0 0 30px rgba(232,184,75,.3);
}

/* Responsive */
@media (max-width: 768px) {
    .hm-hero-inner    { grid-template-columns: 1fr; }
    .hm-hero-logo-wrap { display: none; }
    .hm-hero-actions  { flex-direction: column; }
    .hm-hero-actions .btn-primary,
    .hm-hero-actions .hm-btn-ghost { width: 100%; justify-content: center; }
    .hm-account-card  { flex-direction: column; gap: 24px; padding: 28px 24px; }
    .hm-account-logo  { width: 88px; height: 88px; }
    .hm-points        { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .hm-svc-item-grid { grid-template-columns: 1fr !important; }
}

/* ==========================================================================
   FRONT PAGE — Service Cards & Logo
   ========================================================================== */

/* 2サービスカードグリッド */
.fp-svc-grid { display: flex; flex-direction: column; gap: 20px; }

.fp-svc-card {
    display: grid; grid-template-columns: 1fr 260px;
    border-radius: var(--r-2xl); overflow: hidden;
    border: 1px solid var(--c-border);
    transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.fp-svc-card:hover { box-shadow: var(--sh-lg); transform: translateY(-2px); }

/* リファラルカード */
.fp-svc-card--ref { background: var(--c-surface); }
.fp-svc-card-body { padding: 36px 36px 32px; }

/* SNSカード */
.fp-svc-card--sns { background: #0a1a2e; border-color: rgba(232,184,75,.15); }
.fp-svc-card--sns .fp-svc-card-body { padding: 36px 36px 32px; }

/* ヘッダー部 */
.fp-svc-header { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.fp-svc-num { font-size: .625rem; font-weight: 700; letter-spacing: .14em; color: var(--c-primary); }
.fp-svc-logo { height: 36px; width: auto; }

/* ホクメシロゴ */
.fp-hm-logo-wrap { display: flex; align-items: center; gap: 10px; }
.fp-hm-logo { width: 40px; height: 40px; border-radius: 50%; box-shadow: 0 0 16px rgba(232,184,75,.3); }
.fp-hm-name { display: block; font-size: .8125rem; font-weight: 700; color: rgba(255,255,255,.85); }
.fp-hm-handle { display: block; font-size: .6875rem; color: rgba(255,255,255,.4); }

/* 説明文 */
.fp-svc-desc { font-size: .9rem; color: var(--c-text-sub); line-height: 1.85; margin-bottom: 20px; }

/* チェックリスト */
.fp-svc-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.fp-svc-list li { display: flex; align-items: center; gap: 10px; font-size: .875rem; color: var(--c-text-sub); }
.fp-svc-list--dark li { color: rgba(255,255,255,.65); }

/* ボタン群 */
.fp-svc-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.fp-svc-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 24px; border-radius: var(--r-full);
    background: var(--c-primary); color: #fff;
    font-size: .875rem; font-weight: 700; text-decoration: none;
    transition: all var(--dur) var(--ease);
}
.fp-svc-btn:hover { background: var(--c-primary-dk); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(232,82,26,.3); opacity: 1; }

.fp-svc-btn-gold {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 24px; border-radius: var(--r-full);
    background: #e8b84b; color: #0a1a2e;
    font-size: .875rem; font-weight: 800; text-decoration: none;
    transition: all var(--dur) var(--ease);
}
.fp-svc-btn-gold:hover { background: #f5d06a; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(232,184,75,.35); opacity: 1; }

.fp-svc-contact-link {
    font-size: .8125rem; color: var(--c-text-muted); font-weight: 600;
    text-decoration: none; transition: color var(--dur) var(--ease);
}
.fp-svc-contact-link:hover { color: var(--c-primary); opacity: 1; }

/* サイドパネル */
.fp-svc-card-side {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 20px; padding: 32px 24px; text-align: center;
}
.fp-svc-card-side--ref { background: #FEF0EB; }
.fp-svc-card-side--sns { background: rgba(255,255,255,.03); border-left: 1px solid rgba(255,255,255,.06); }

.fp-svc-badge {
    font-size: .625rem; font-weight: 700; letter-spacing: .12em;
    padding: 5px 14px; border-radius: var(--r-full);
    background: var(--c-primary); color: #fff;
}
.fp-svc-badge--gold { background: #e8b84b; color: #0a1a2e; }

/* リファラルビジュアル */
.fp-svc-visual-ref { display: flex; align-items: center; gap: 10px; }
.fp-ref-node { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.fp-ref-node-icon {
    width: 44px; height: 44px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.fp-ref-node--left .fp-ref-node-icon { background: var(--c-primary); }
.fp-ref-node--right .fp-ref-node-icon { background: var(--c-dark); }
.fp-ref-node span { font-size: .625rem; font-weight: 700; color: var(--c-text-muted); letter-spacing: .05em; }
.fp-ref-arrow { display: flex; flex-direction: column; align-items: center; }

.fp-svc-stat { }
.fp-svc-stat-num { display: block; font-size: 1.375rem; font-weight: 900; color: var(--c-primary); letter-spacing: -.03em; }
.fp-svc-stat-label { font-size: .625rem; color: var(--c-text-muted); letter-spacing: .04em; }

/* SNSサイドロゴ */
.fp-sns-logo-large { width: 120px; height: 120px; border-radius: 50%; box-shadow: 0 0 40px rgba(232,184,75,.25); }
.fp-sns-ig-link {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .75rem; color: rgba(255,255,255,.45); text-decoration: none;
    border: 1px solid rgba(255,255,255,.12); padding: 7px 14px; border-radius: var(--r-full);
    transition: all var(--dur) var(--ease);
}
.fp-sns-ig-link:hover { color: #fff; border-color: rgba(255,255,255,.3); opacity: 1; }

/* レスポンシブ */
@media (max-width: 768px) {
    .fp-svc-card { grid-template-columns: 1fr; }
    .fp-svc-card-side { display: none; }
    .fp-svc-card-body { padding: 24px 20px; }
}

/* ==========================================================================
   ロゴ画像（新ロゴ対応）
   ========================================================================== */
.logo-lockup { display: inline-flex; align-items: center; gap: 10px; }
.logo-mark-img {
    height: 40px; width: 40px;
    object-fit: contain;
    display: block;
    border-radius: 8px;
    mix-blend-mode: multiply; /* 白背景をヘッダーに馴染ませる */
}
.logo-lockup .logo-text {
    font-size: 1.3rem; font-weight: 900;
    color: var(--c-dark); letter-spacing: -.04em;
    line-height: 1;
}
@media (max-width: 480px) {
    .logo-mark-img { height: 34px; width: 34px; }
    .logo-lockup .logo-text { font-size: 1.15rem; }
}

/* フッターロゴ（ダーク背景用：白丸背景で視認性確保） */
.footer-logo-mark {
    height: 38px; width: 38px;
    object-fit: contain;
    background: #fff;
    border-radius: 9px;
    padding: 4px;
    display: block;
}
.footer-logo-wrap { display: inline-flex; align-items: center; gap: 10px; }

/* ヒーロー：ロゴマークを大きく見せるステージ */
.hero-logo-stage {
    display: flex; flex-direction: column; align-items: center; gap: 28px;
}
.hero-logo-mark {
    width: 220px; height: 220px; object-fit: contain;
    background: #fff;
    border-radius: var(--r-2xl);
    padding: 28px;
    box-shadow: 0 24px 60px rgba(0,0,0,.35),
                0 0 0 1px rgba(255,255,255,.06),
                0 8px 30px rgba(232,82,26,.18);
}
.hero-logo-stage .hero-stats {
    display: flex; flex-direction: row; gap: 0;
    background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--r-xl); overflow: hidden;
}
.hero-logo-stage .hero-stat {
    padding: 16px 22px; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 0;
}
.hero-logo-stage .hero-stat + .hero-stat { border-top: none; border-left: 1px solid rgba(255,255,255,.07); }
.hero-logo-stage .hero-stat-num { font-size: 1.4rem; }
@media (max-width: 768px) {
    .hero-side { display: flex !important; margin-top: 8px; }
    .hero-logo-mark { width: 150px; height: 150px; padding: 20px; border-radius: var(--r-xl); }
    .hero-logo-stage { gap: 20px; }
}

/* ==========================================================================
   モーション・インタラクション
   ========================================================================== */

/* スクロールリビール（基本：下からふわっと） */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .7s var(--ease), transform .7s var(--ease);
    will-change: opacity, transform;
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}
/* バリエーション */
.reveal--left  { transform: translateX(-32px); }
.reveal--right { transform: translateX(32px); }
.reveal--left.is-visible,
.reveal--right.is-visible { transform: translateX(0); }
.reveal--scale { transform: scale(.94); }
.reveal--scale.is-visible { transform: scale(1); }

/* ヘッダー：スクロール反応 */
.site-header {
    transition: height var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease),
                background var(--dur) var(--ease);
}
.site-header.is-scrolled {
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    background: rgba(255,255,255,.92);
}
.site-header.is-scrolled .header-inner { height: 62px; }
.header-inner { transition: height var(--dur) var(--ease); }

/* ヒーロー：初期ロードアニメーション */
@keyframes heroIn {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}
.hero-content > * { opacity: 0; animation: heroIn .7s var(--ease) forwards; }
.hero-content > .hero-label   { animation-delay: .05s; }
.hero-content > .hero-heading { animation-delay: .18s; }
.hero-content > .hero-body    { animation-delay: .32s; }
.hero-content > .hero-actions { animation-delay: .46s; }
@keyframes heroMarkIn {
    from { opacity: 0; transform: scale(.9) translateY(10px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.hero-logo-mark { opacity: 0; animation: heroMarkIn .9s var(--ease) .3s forwards; }
.hero-logo-stage .hero-stats { opacity: 0; animation: heroIn .7s var(--ease) .6s forwards; }

/* ボタン：押下のマイクロインタラクション */
.btn-primary, .btn-dark, .btn-outline, .btn-outline-white,
.fp-svc-btn, .fp-svc-btn-gold, .hm-btn-ghost {
    will-change: transform;
}
.btn-primary:active, .btn-dark:active, .btn-outline:active,
.fp-svc-btn:active, .fp-svc-btn-gold:active { transform: translateY(1px) scale(.99); }

/* リンク矢印のホバー時スライド */
.fp-svc-btn svg, .fp-svc-btn-gold svg { transition: transform var(--dur) var(--ease); }
.fp-svc-btn:hover svg, .fp-svc-btn-gold:hover svg { transform: translateX(4px); }

/* サービスカードのホバー（既存に上乗せ） */
.fp-svc-card { will-change: transform; }
.fp-svc-card:hover .fp-svc-logo { transform: scale(1.02); }
.fp-svc-logo { transition: transform var(--dur) var(--ease); }

/* フローステップの番号がホバーで弾む */
.flow-step { will-change: transform; }
.flow-step:hover { transform: translateY(-4px); }
.flow-step .flow-step-num { transition: transform var(--dur) var(--ease); }
.flow-step:hover .flow-step-num { transform: scale(1.08); }

/* 矢印アイコンの常時ゆらぎ（ご利用の流れ） */
@keyframes nudge {
    0%, 100% { transform: translateX(0); }
    50%      { transform: translateX(4px); }
}
.flow-arrow svg { animation: nudge 2s var(--ease) infinite; }

/* エリアカード・案件カードのホバー微動（既存補強） */
.area-card, .project-item, .merit-card, .hm-point, .feature-card, .reason-card {
    will-change: transform;
}

/* prefers-reduced-motion: すべての装飾モーションを無効化 */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
        scroll-behavior: auto !important;
    }
    .reveal { opacity: 1; transform: none; }
    .hero-content > *, .hero-logo-mark, .hero-logo-stage .hero-stats { opacity: 1; animation: none; }
    .flow-arrow svg { animation: none; }
}
