@import url('https://fonts.googleapis.com/css2?family=LINE+Seed+JP:wght@100;400;700;800&display=swap');

        /* ===== CSS VARIABLES ===== */
        :root {
            --primary: #06c755;
            --primary-dark: #04a344;
            --product: #0aa9a3;
            --sub-primary: #2e75b6;
            --attention: #ef4444;
            --accent: #ffb800;
            --text-dark: #333333;
            --text-light: #7d7d7d;
            --white: #ffffff;
            --bg-light: #f7faf9;
            --bg-section: #f0f9f4;
            --border: #e8f5ee;
            --radius: 8px;
            --radius-lg: 16px;
            --radius-xl: 24px;
            --shadow: 0 4px 24px rgba(6,199,85,0.10);
            --shadow-card: 0 2px 16px rgba(51,51,51,0.08);
            --transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
        }

        /* ===== RESET & BASE ===== */
        *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
        html { scroll-behavior: smooth; font-size: 16px; }
        body {
            font-family: "LINE Seed JP", sans-serif;
            color: var(--text-dark);
            background: var(--white);
            line-height: 1.7;
            -webkit-font-smoothing: antialiased;
        }
        img { max-width: 100%; height: auto; display: block; }
        a { color: inherit; text-decoration: none; }
        ul { list-style: none; }

        /* ===== UTILITY ===== */
        .container {
            max-width: 1100px;
            margin: 0 auto;
            padding: 0 24px;
        }
        .section-pad {
            padding: 88px 0;
        }
        .tag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-size: 0.75rem;
            font-weight: 700;
            letter-spacing: 0.08em;
            padding: 4px 14px;
            border-radius: 999px;
            text-transform: uppercase;
        }

        /* ===== CTA BUTTON ===== */
        .btn-cta {
            position: relative;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            background: var(--primary);
            color: var(--white);
            font-size: 1rem;
            font-weight: 700;
            padding: 16px 36px;
            border-radius: var(--radius);
            border: none;
            cursor: pointer;
            overflow: hidden;
            transition: color var(--transition), box-shadow var(--transition);
            text-decoration: none;
            box-shadow: 0 4px 18px rgba(6,199,85,0.35);
        }
        .btn-cta::before {
            content: '';
            position: absolute;
            top: 0; left: -100%;
            width: 100%; height: 100%;
            background: var(--primary-dark);
            transition: left var(--transition);
            z-index: 0;
        }
        .btn-cta:hover::before { left: 0; }
        .btn-cta span, .btn-cta i { position: relative; z-index: 1; }
        .btn-cta:hover { box-shadow: 0 6px 28px rgba(6,199,85,0.45); }

        .btn-cta-lg {
            font-size: 1.125rem;
            padding: 20px 48px;
        }

        .btn-outline {
            position: relative;
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: transparent;
            color: var(--primary);
            font-size: 0.9rem;
            font-weight: 700;
            padding: 10px 24px;
            border-radius: var(--radius);
            border: 2px solid var(--primary);
            cursor: pointer;
            overflow: hidden;
            transition: color var(--transition);
            text-decoration: none;
        }
        .btn-outline::before {
            content: '';
            position: absolute;
            top: 0; right: -100%;
            width: 100%; height: 100%;
            background: var(--primary);
            transition: right var(--transition);
            z-index: 0;
        }
        .btn-outline:hover::before { right: 0; }
        .btn-outline:hover { color: var(--white); }
        .btn-outline span, .btn-outline i { position: relative; z-index: 1; }

        /* ===== SECTION HEADINGS ===== */
        .section-label {
            font-size: 0.8rem;
            font-weight: 700;
            letter-spacing: 0.14em;
            text-transform: uppercase;
            color: var(--primary);
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .section-label::before {
            content: '';
            display: block;
            width: 24px;
            height: 3px;
            background: var(--primary);
            border-radius: 2px;
        }
        h2.section-title {
            font-size: clamp(1.6rem, 3vw, 2.2rem);
            font-weight: 800;
            line-height: 1.35;
            color: var(--text-dark);
            margin-bottom: 16px;
        }
        h3.section-sub {
            font-size: clamp(1.05rem, 2vw, 1.25rem);
            font-weight: 700;
            color: var(--text-dark);
            margin-bottom: 12px;
        }
        p.section-text {
            font-size: 0.975rem;
            color: var(--text-dark);
            line-height: 1.85;
        }

        /* ===== STICKY NAV ===== */
        .site-nav {
            position: sticky;
            top: 0;
            z-index: 100;
            background: rgba(255,255,255,0.97);
            backdrop-filter: blur(10px);
            border-bottom: 1px solid var(--border);
            padding: 0 24px;
        }
        .site-nav .nav-inner {
            max-width: 1080px;
            margin: 0 auto;
            display: flex;
            align-items: center;
            justify-content: space-between;
            height: 64px;
        }
		
		.nav-logo{ 
			width: clamp(150px, 50%, 400px);
			height: auto;
			align-content: center;
		}
		
		.nav-logo img{
			width: 60%;
		}
        .nav-cta {
            display: flex;
            align-items: center;
            gap: 12px;
        }

        /* ===== HEADER ===== */
        header {
            background: linear-gradient(135deg, #04a344 0%, #06c755 45%, #0aa9a3 100%);
            position: relative;
            overflow: hidden;
            display: flex;
            align-items: center;
        }


        .header-inner {
            position: relative;
            z-index: 2;
            max-width: 1100px;
            margin: 0 auto;
            padding: 72px 24px;
            display: grid;
            grid-template-columns: 1fr 500px;
            gap: 48px;
            align-items: center;
			background: url("https://corporate-site-public-bucket.s3.ap-northeast-1.amazonaws.com/images/lp/dodx_img_kv_001.png") right 0 no-repeat;
			background-size: 60%;
        }
        .header-h1 {
            font-size: clamp(2rem, 4.5vw, 3rem);
            font-weight: 800;
            color: var(--white);
            line-height: 1.25;
            margin-bottom: 20px;
            letter-spacing: -0.01em;
        }
        .header-lead {
            font-size: 1rem;
            color: rgba(255,255,255,0.88);
            line-height: 1.8;
            margin-bottom: 36px;
            max-width: 480px;
        }
        .header-cta-area {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 16px;
        }
        .btn-cta-white {
            position: relative;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            background: var(--white);
            color: var(--primary-dark);
            font-size: 1.05rem;
            font-weight: 800;
            padding: 18px 40px;
            border-radius: var(--radius);
            border: none;
            cursor: pointer;
            overflow: hidden;
            transition: color var(--transition), box-shadow var(--transition);
            text-decoration: none;
            box-shadow: 0 4px 24px rgba(0,0,0,0.18);
        }
        .btn-cta-white::before {
            content: '';
            position: absolute;
            top: 0; left: -100%;
            width: 100%; height: 100%;
            background: #e8fdf0;
            transition: left var(--transition);
            z-index: 0;
        }
        .btn-cta-white:hover::before { left: 0; }
        .btn-cta-white span, .btn-cta-white i { position: relative; z-index: 1; }
		
		.header_ambassador{ font-size: clamp(8px, 2vw, 11px); color: var(--white); font-weight: 600; margin: 0 0 0 auto; position: absolute; right: 0; bottom: 20px;}


        /* ===== MENU NAV ===== */
        .menu-section {
            background: var(--white);
            border-bottom: 1px solid var(--border);
            padding: 0;
			max-width: 1200px;
			margin: 0 auto;
        }
        .menu-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 0;
        }
        .menu-card {
            padding: 36px 32px;
            border-right: 1px solid var(--border);
            transition: background var(--transition);
            text-decoration: none;
            color: inherit;
        }
        .menu-card:last-child { border-right: none; }
        .menu-card:hover { background: var(--bg-section); }
        .menu-card-icon {
            width: 48px;
            height: 48px;
            border-radius: var(--radius);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.4rem;
            margin-bottom: 16px;
        }
        .icon-a { background: #e8fdf0; color: var(--primary); }
        .icon-b { background: #e6f4fb; color: var(--sub-primary); }
        .icon-c { background: #e8f9f9; color: var(--product); }
        .menu-card-title {
            font-size: 1rem;
            font-weight: 800;
            color: var(--text-dark);
            margin-bottom: 6px;
        }
        .menu-card-products {
            font-size: 0.82rem;
            color: var(--text-light);
            margin-bottom: 16px;
            line-height: 1.6;
        }
        .menu-card-products span {
            display: inline-block;
            background: var(--bg-section);
            border-radius: 4px;
            padding: 2px 8px;
            margin: 2px 2px 0 0;
            font-size: 0.78rem;
        }

        /* ===== SECTION A ===== */
        #sectionA {
            background: var(--bg-light);
        }
        .section-a-inner {
            display: grid;
            grid-template-columns: 1fr 380px;
            gap: 64px;
            align-items: center;
        }
        .icons-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 12px;
            margin: 28px 0;
        }
        .icon-chip {
            background: var(--white);
            border: 1px solid var(--border);
            border-radius: var(--radius);
            padding: 14px 10px;
            text-align: center;
            font-size: 0.75rem;
            font-weight: 700;
            color: var(--text-dark);
            transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
        }
        .icon-chip:hover {
            border-color: var(--primary);
            box-shadow: 0 2px 12px rgba(6,199,85,0.15);
            transform: translateY(-2px);
        }
        .icon-chip i {
            display: block;
            font-size: 1.3rem;
            color: var(--primary);
            margin-bottom: 6px;
        }
        .phone-mockup {
            background: var(--white);
            border-radius: 32px;
            box-shadow: 0 24px 64px rgba(51,51,51,0.16), 0 4px 16px rgba(6,199,85,0.1);
            padding: 28px 20px;
            border: 8px solid #222;
            position: relative;
        }
        .phone-mockup::before {
            content: '';
            display: block;
            width: 80px;
            height: 6px;
            background: #222;
            border-radius: 3px;
            margin: 0 auto 20px;
        }
        .phone-screen {
            background: linear-gradient(160deg, #e8fdf0 0%, #e8f9f9 100%);
            border-radius: 16px;
            padding: 20px 16px;
            min-height: 320px;
            display: flex;
            flex-direction: column;
            gap: 10px;
        }
        .phone-app-bar {
            background: var(--primary);
            border-radius: 8px;
            padding: 10px 14px;
            color: white;
            font-size: 0.75rem;
            font-weight: 700;
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .phone-menu-item {
            background: white;
            border-radius: 8px;
            padding: 12px 14px;
            font-size: 0.78rem;
            font-weight: 700;
            color: var(--text-dark);
            display: flex;
            align-items: center;
            gap: 8px;
            box-shadow: 0 1px 4px rgba(0,0,0,0.06);
        }
        .phone-menu-item i { color: var(--primary); font-size: 1rem; }

        /* ===== SECTION B ===== */
        #sectionB {
            background: var(--white);
        }
        .crm-cards {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 24px;
            margin-top: 40px;
        }
        .crm-card {
            background: var(--bg-light);
            border: 1.5px solid var(--border);
            border-radius: var(--radius-lg);
            padding: 36px 32px;
            position: relative;
            overflow: hidden;
            transition: box-shadow var(--transition), transform var(--transition);
        }
        .crm-card:hover {
            box-shadow: var(--shadow-card);
            transform: translateY(-3px);
        }
        .crm-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 4px;
        }
        .crm-card.card-crm::before { background: var(--sub-primary); }
        .crm-card.card-direct::before { background: var(--product); }
        .crm-card-icon {
            width: 52px;
            height: 52px;
            border-radius: var(--radius);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.5rem;
            margin-bottom: 20px;
        }
        .crm-card.card-crm .crm-card-icon { background: #e6f4fb; color: var(--sub-primary); }
        .crm-card.card-direct .crm-card-icon { background: #e8f9f9; color: var(--product); }
        .crm-card-name {
            font-size: 0.78rem;
            font-weight: 700;
            letter-spacing: 0.1em;
            text-transform: uppercase;
            margin-bottom: 8px;
        }
        .crm-card.card-crm .crm-card-name { color: var(--sub-primary); }
        .crm-card.card-direct .crm-card-name { color: var(--product); }

        /* ===== SECTION C ===== */
        #sectionC {
            background: var(--bg-light);
        }
        .industry-cards {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 28px;
            margin-top: 40px;
        }
        .industry-card {
            background: var(--white);
            border-radius: var(--radius-lg);
            overflow: hidden;
            box-shadow: var(--shadow-card);
            transition: box-shadow var(--transition), transform var(--transition);
        }
        .industry-card:hover {
            box-shadow: 0 8px 36px rgba(51,51,51,0.14);
            transform: translateY(-4px);
        }
        .industry-card-header {
            padding: 24px 28px 20px;
            display: flex;
            align-items: center;
            gap: 14px;
        }
        .industry-tag-icon {
            width: 48px;
            height: 48px;
            border-radius: var(--radius);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.4rem;
            flex-shrink: 0;
        }
        .card-restaurant .industry-tag-icon { background: #fff3e8; color: #e8632a; }
        .card-beauty .industry-tag-icon { background: #fce8f5; color: #c7398e; }
        .industry-card-badge {
            font-size: 0.72rem;
            font-weight: 700;
            letter-spacing: 0.1em;
            text-transform: uppercase;
            padding: 3px 10px;
            border-radius: 4px;
        }
        .card-restaurant .industry-card-badge { background: #fff3e8; color: #e8632a; }
        .card-beauty .industry-card-badge { background: #fce8f5; color: #c7398e; }
        .industry-card-body {
            padding: 0 28px 28px;
        }
        .feature-list {
            margin-top: 16px;
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .feature-list li {
            display: flex;
            align-items: flex-start;
            gap: 8px;
            font-size: 0.85rem;
            color: var(--text-light);
        }
        .feature-list li::before {
            content: '\f00c';
            font-family: 'Font Awesome 6 Free';
            font-weight: 900;
            color: var(--primary);
            font-size: 0.75rem;
            margin-top: 3px;
            flex-shrink: 0;
        }

        /* ===== SECTION D - CAMPAIGN ===== */
        #sectionD {
            background: linear-gradient(135deg, #1a3a5c 0%, #2e75b6 50%, #0aa9a3 100%);
            position: relative;
            overflow: hidden;
        }
        #sectionD::before {
            content: '';
            position: absolute;
            inset: 0;
            background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
        }
        #sectionD .container {
            position: relative;
            z-index: 1;
            text-align: center;
        }
        .campaign-badge {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: rgba(255,184,0,0.2);
            border: 1.5px solid rgba(255,184,0,0.5);
            color: var(--accent);
            border-radius: 999px;
            padding: 6px 20px;
            font-size: 0.82rem;
            font-weight: 700;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            margin-bottom: 20px;
        }
        .campaign-h2 {
            font-size: clamp(1.8rem, 4vw, 2.8rem);
            font-weight: 800;
            color: var(--white);
            margin-bottom: 12px;
            line-height: 1.3;
        }
        .campaign-sub {
            font-size: 1.1rem;
            color: rgba(255,255,255,0.8);
            margin-bottom: 40px;
        }

        /* ===== SECTION E - PARTNER ===== */
        #sectionE {
            background: var(--white);
        }
        .partner-inner {
            display: grid;
            grid-template-columns: 1fr 320px;
            gap: 64px;
            align-items: center;

        }
		
		.partner-badges img{
			max-width: 70%;
		}
        .badge-placeholder {
            text-align: center;
        }
		.badge-placeholder img{
			max-height: 550px;
			margin: 0 auto;
        }

		
		.text-note{
			font-size: clamp(10px, 2vw, 11px);
			color: var(--text-light);
		}

        /* ===== FINAL CTA SECTION ===== */
        .final-cta {
            background: var(--bg-section);
            padding: 72px 0;
            text-align: center;
            border-top: 1px solid var(--border);
        }

        /* ===== FOOTER ===== */
        footer {
            background: #1a1a1a;
            color: rgba(255,255,255,0.7);
            padding: 56px 0 28px;
        }
        .footer-inner {
            max-width: 1100px;
            margin: 0 auto;
            padding: 0 24px;
        }
        .footer-logo {
            margin-bottom: 24px;
        }
		.footer-logo img{
			max-width: 40%;
		}
        .footer-company {
            font-size: 0.88rem;
            line-height: 1.8;
            margin-bottom: 24px;
        }
        .footer-grid {
            display: grid;
            grid-template-columns: 1.5fr 1fr 1fr;
            gap: 40px;
            padding-bottom: 40px;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            margin-bottom: 24px;
        }
        .footer-links {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }
        .footer-links h4 {
            font-size: 0.8rem;
            font-weight: 700;
            letter-spacing: 0.1em;
            text-transform: uppercase;
            color: rgba(255,255,255,0.4);
            margin-bottom: 8px;
        }
        .footer-links a {
            font-size: 0.85rem;
            color: rgba(255,255,255,0.65);
            transition: color var(--transition);
        }
        .footer-links a:hover { color: var(--primary); }
        .footer-copy {
            font-size: 0.78rem;
            color: rgba(255,255,255,0.4);
            text-align: center;
        }
		
		.marker01{ color: var(--primary);}
		.marker02{ color: var(--product);}
		.marker03{ color: var(--sub-primary);}

        /* ===== SCROLL REVEAL ===== */
        .reveal {
            opacity: 0;
            transform: translateY(28px);
            transition: opacity 0.6s ease, transform 0.6s ease;
        }
        .reveal.visible {
            opacity: 1;
            transform: translateY(0);
        }

        /* ===== RESPONSIVE ===== */
        @media (max-width: 900px) {
			.nav-logo img{ width: 80%;}
            .header-inner {
                grid-template-columns: 1fr;
                padding: 48px 24px;
				min-height: 450px;
            }
            .menu-grid {
                grid-template-columns: 1fr;
            }
            .menu-card { border-right: none; border-bottom: 1px solid var(--border); }
            .menu-card:last-child { border-bottom: none; }
            .section-a-inner {
                grid-template-columns: 1fr;
            }
            .crm-cards { grid-template-columns: 1fr; }
            .industry-cards { grid-template-columns: 1fr; }
            .partner-inner { grid-template-columns: 1fr; }
            .footer-grid { grid-template-columns: 1fr; gap: 24px; }
            .icons-grid { grid-template-columns: repeat(3, 1fr); }
        }
        @media (max-width: 600px) {
            .section-pad { padding: 56px 0; }
            h2.section-title { font-size: 1.45rem; }
            .icons-grid { grid-template-columns: repeat(2, 1fr); }
            .btn-cta-lg { padding: 16px 28px; font-size: 1rem; }
			.badge-placeholder{ display: none;}
        }