*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:#1f2530;background:#faf7f2;line-height:1.75;font-size:16px}
h1,h2,h3,h4,h5,h6{font-family:'Noto Serif JP',serif;color:#1f2530;font-weight:600;line-height:1.4}
a{color:#1f2530;text-decoration:none;transition:color .25s ease}
a:hover{color:#c45824}
img{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}

.site-header{background:#faf7f2;border-bottom:1px solid #e8e1d4;position:sticky;top:0;z-index:50}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.brand{display:flex;flex-direction:column;font-family:'Noto Serif JP',serif}
.brand-name{font-size:18px;font-weight:700;color:#1f2530}
.brand-sub{font-size:11px;color:#6b6558;letter-spacing:.04em}
.nav-menu{display:flex;align-items:center;gap:28px;list-style:none}
.nav-menu a{font-size:14px;color:#3a3b3f;position:relative}
.nav-menu .has-sub{position:relative}
.nav-menu .submenu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e8e1d4;box-shadow:0 4px 18px rgba(31,37,48,.06);min-width:280px;padding:12px 0;list-style:none;opacity:0;visibility:hidden;transform:translateY(6px);transition:all .2s ease}
.nav-menu .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-menu .submenu li{padding:0}
.nav-menu .submenu a{display:block;padding:10px 18px;font-size:13.5px;color:#3a3b3f}
.nav-menu .submenu a:hover{background:#f4efe5;color:#c45824}
.nav-cta{display:inline-block;background:#c45824;color:#fff !important;padding:10px 20px;border-radius:2px;font-size:13.5px;font-weight:500;border:1px solid #c45824;transition:all .25s ease}
.nav-cta:hover{background:#a94817;border-color:#a94817;color:#fff !important}
.hamburger{display:none;background:none;border:none;font-size:22px;color:#1f2530;cursor:pointer}

.hero{background:#faf7f2;padding:72px 0 88px;border-bottom:1px solid #ece5d7}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.hero-text h1{font-size:44px;margin-bottom:16px;letter-spacing:.01em}
.hero-text .tagline{font-size:17px;color:#4c4a45;margin-bottom:14px;font-family:'Noto Serif JP',serif}
.hero-text p{font-size:15px;color:#4c4a45;margin-bottom:28px;max-width:560px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:13px 26px;font-size:14px;font-weight:500;border-radius:2px;transition:all .25s ease;cursor:pointer;border:1px solid transparent;font-family:inherit}
.btn-primary{background:#c45824;color:#fff;border-color:#c45824}
.btn-primary:hover{background:#a94817;border-color:#a94817;color:#fff}
.btn-secondary{background:transparent;color:#1f2530;border-color:#1f2530}
.btn-secondary:hover{background:#1f2530;color:#fff}
.hero-visual{position:relative;min-height:460px;border-radius:3px;overflow:hidden;background:linear-gradient(135deg,rgba(31,37,48,.25),rgba(196,88,36,.18)),url('../visuals/home-hero-camera-lens.jpg') center/cover no-repeat;background-color:#2b2f38}

.section{padding:80px 0}
.section-alt{background:#f4efe5}
.section-title{font-size:30px;margin-bottom:12px}
.section-lead{font-size:15px;color:#5a5852;max-width:720px;margin-bottom:40px}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:.22em;color:#c45824;text-transform:uppercase;margin-bottom:12px;font-weight:600}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-icons{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}
.about-icon{display:flex;gap:12px;align-items:flex-start}
.about-icon i{color:#c45824;font-size:20px;padding-top:3px}
.about-icon h4{font-size:14.5px;margin-bottom:4px}
.about-icon p{font-size:13px;color:#5a5852}
.about-img{border-radius:3px;overflow:hidden;border:1px solid #e8e1d4}
.about-img img{width:100%;height:100%;object-fit:cover;min-height:360px}

.grid-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid #e8e1d4;border-radius:3px;overflow:hidden;transition:all .3s ease;box-shadow:0 1px 3px rgba(31,37,48,.03)}
.card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(31,37,48,.08);border-color:#d5caa8}
.card-image{width:100%;aspect-ratio:16/10;background:#2b2f38;background-size:cover;background-position:center}
.card-body{padding:22px 22px 24px}
.card-date{font-size:12px;color:#8a8579;letter-spacing:.08em;margin-bottom:8px}
.card h3{font-size:18px;margin-bottom:10px;line-height:1.45}
.card p{font-size:13.5px;color:#5a5852;margin-bottom:14px}
.card-link{color:#c45824;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.card-link i{font-size:11px;transition:transform .25s ease}
.card:hover .card-link i{transform:translateX(4px)}

.advantages{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.adv-card{background:#fff;border:1px solid #e8e1d4;padding:30px 24px;border-radius:3px;transition:all .3s ease}
.adv-card:hover{border-color:#c45824;box-shadow:0 6px 18px rgba(196,88,36,.08)}
.adv-icon{width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:#faf2e8;color:#c45824;border-radius:50%;font-size:18px;margin-bottom:16px}
.adv-card h4{font-size:16px;margin-bottom:10px}
.adv-card p{font-size:13.5px;color:#5a5852}

.mission{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
.mission-img{border-radius:3px;overflow:hidden;border:1px solid #e8e1d4}
.mission-img img{width:100%;min-height:340px;object-fit:cover}
.mission-text h2{font-size:28px;margin-bottom:16px}
.mission-text p{font-size:15px;color:#4c4a45;margin-bottom:14px}

.faq-list{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid #e8e1d4;border-radius:3px;margin-bottom:14px;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:20px 24px;background:transparent;border:none;font-size:15.5px;font-family:'Noto Serif JP',serif;font-weight:600;color:#1f2530;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-q i{color:#c45824;transition:transform .3s ease;font-size:14px}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:all .35s ease;font-size:14.5px;color:#4c4a45}
.faq-item.open .faq-a{padding:0 24px 22px;max-height:400px}

.closing{background:#1f2530;color:#f4efe5;padding:72px 0;text-align:center}
.closing h2{color:#faf7f2;font-size:30px;margin-bottom:14px}
.closing p{color:#c9c3b4;font-size:15px;max-width:640px;margin:0 auto 30px}
.closing .btn-primary{background:#c45824;border-color:#c45824}
.closing .btn-secondary{color:#faf7f2;border-color:#faf7f2}
.closing .btn-secondary:hover{background:#faf7f2;color:#1f2530}

.site-footer{background:#14181f;color:#c9c3b4;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1.3fr;gap:44px;padding-bottom:44px}
.footer-col h5{font-family:'Noto Serif JP',serif;color:#faf7f2;font-size:15px;margin-bottom:18px;letter-spacing:.05em}
.footer-contact p{font-size:13.5px;margin-bottom:12px;display:flex;gap:10px;align-items:flex-start;color:#c9c3b4}
.footer-contact i{color:#c45824;padding-top:3px;min-width:16px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul a{color:#c9c3b4;font-size:13.5px}
.footer-col ul a:hover{color:#c45824}
.subscribe-form input[type=text],.subscribe-form input[type=email]{width:100%;padding:10px 12px;background:#1f2530;border:1px solid #2f3540;color:#faf7f2;font-size:13.5px;margin-bottom:10px;border-radius:2px;font-family:inherit}
.subscribe-form input:focus{outline:none;border-color:#c45824}
.subscribe-check{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:#9e998b;margin-bottom:14px}
.subscribe-check input{margin-top:3px}
.subscribe-form button{width:100%;padding:11px;background:#c45824;color:#fff;border:none;font-size:13.5px;cursor:pointer;border-radius:2px;font-family:inherit;transition:background .25s ease}
.subscribe-form button:hover{background:#a94817}
.footer-bottom{border-top:1px solid #2a2f38;padding:22px 0;text-align:center;font-size:12.5px;color:#8a8579}

.page-hero{padding:60px 0 48px;background:#f4efe5;border-bottom:1px solid #e8e1d4}
.page-hero h1{font-size:36px;margin-bottom:10px}
.page-hero p{color:#5a5852;font-size:15px;max-width:720px}
.breadcrumb{font-size:12.5px;color:#8a8579;margin-bottom:14px}
.breadcrumb a{color:#8a8579}
.breadcrumb a:hover{color:#c45824}

.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;margin-bottom:48px}
.contact-info-card{background:#fff;border:1px solid #e8e1d4;padding:32px;border-radius:3px}
.contact-info-card h3{font-size:20px;margin-bottom:20px}
.contact-info-card ul{list-style:none}
.contact-info-card li{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px;font-size:14px;color:#3a3b3f}
.contact-info-card i{color:#c45824;font-size:18px;padding-top:3px;min-width:20px}
.contact-info-card small{display:block;color:#8a8579;font-size:12px;margin-top:2px}
.contact-form-card{background:#fff;border:1px solid #e8e1d4;padding:32px;border-radius:3px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13.5px;font-weight:500;margin-bottom:6px;color:#3a3b3f}
.form-group input,.form-group textarea{width:100%;padding:11px 13px;border:1px solid #dcd3c0;background:#faf7f2;font-size:14px;font-family:inherit;border-radius:2px;color:#1f2530}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#c45824;background:#fff}
.form-group textarea{min-height:140px;resize:vertical}
.form-note{font-size:12px;color:#8a8579;margin-top:-10px;margin-bottom:16px}
.map-wrap{position:relative;width:100%;padding-bottom:42%;background:#e8e1d4;border:1px solid #e8e1d4;border-radius:3px;overflow:hidden;margin-bottom:20px}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-link{font-size:13.5px;color:#c45824}

.article-wrap{display:grid;grid-template-columns:1fr;gap:40px;max-width:840px;margin:0 auto;padding:60px 0}
.article-meta{font-size:13px;color:#8a8579;margin-bottom:14px}
.article-title{font-size:36px;line-height:1.35;margin-bottom:18px}
.article-hero{width:100%;aspect-ratio:16/9;background:#2b2f38;background-size:cover;background-position:center;border-radius:3px;margin-bottom:28px}
.article-body h2{font-size:24px;margin:40px 0 16px;padding-bottom:8px;border-bottom:1px solid #e8e1d4}
.article-body h3{font-size:19px;margin:24px 0 12px}
.article-body p{font-size:15.5px;margin-bottom:18px;color:#2f3338}
.article-body ul,.article-body ol{margin:0 0 18px 22px}
.article-body li{font-size:15px;color:#2f3338;margin-bottom:8px}
.article-body blockquote{border-left:3px solid #c45824;padding:12px 20px;background:#faf2e8;color:#4c4a45;font-size:15px;margin:20px 0;border-radius:0 3px 3px 0}
.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px;padding-top:30px;border-top:1px solid #e8e1d4}
.article-nav a{padding:18px 20px;border:1px solid #e8e1d4;background:#fff;border-radius:3px;font-size:13.5px;transition:all .25s ease}
.article-nav a:hover{border-color:#c45824;background:#faf2e8}
.article-nav .label{display:block;font-size:11px;color:#8a8579;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}
.article-nav .next{text-align:right}
.article-cta{margin-top:36px;padding:26px;background:#faf2e8;border:1px solid #ecd9c2;border-radius:3px;text-align:center}
.article-cta p{margin-bottom:16px;font-size:14.5px;color:#4c4a45}

.list-section{padding:60px 0 80px}
.list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}

.legal-wrap{max-width:860px;margin:0 auto;padding:60px 0}
.legal-wrap h2{font-size:22px;margin:36px 0 14px;padding-bottom:8px;border-bottom:1px solid #e8e1d4}
.legal-wrap h3{font-size:17px;margin:22px 0 10px}
.legal-wrap p{font-size:15px;margin-bottom:14px;color:#2f3338}
.legal-wrap ul{margin:0 0 18px 22px}
.legal-wrap li{font-size:14.5px;color:#2f3338;margin-bottom:8px}
.legal-meta{font-size:13px;color:#8a8579;margin-top:40px;padding-top:20px;border-top:1px solid #e8e1d4}

.cookie-modal{position:fixed;right:24px;bottom:24px;max-width:380px;background:#fff;border:1px solid #e8e1d4;border-radius:4px;box-shadow:0 12px 36px rgba(31,37,48,.18);padding:22px;z-index:100;display:none}
.cookie-modal.active{display:block}
.cookie-modal h4{font-size:16px;margin-bottom:10px}
.cookie-modal p{font-size:13px;color:#4c4a45;margin-bottom:16px}
.cookie-actions{display:flex;gap:10px}
.cookie-actions button{flex:1;padding:10px 14px;font-size:13px;font-family:inherit;cursor:pointer;border-radius:2px;border:1px solid #1f2530;background:#fff;color:#1f2530;transition:all .25s ease}
.cookie-actions .accept{background:#c45824;border-color:#c45824;color:#fff}
.cookie-actions .accept:hover{background:#a94817;border-color:#a94817}
.cookie-actions .reject:hover{background:#1f2530;color:#fff}

.success-modal{position:fixed;inset:0;background:rgba(20,24,31,.6);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.success-modal.active{display:flex}
.success-box{background:#fff;padding:36px;border-radius:4px;max-width:440px;text-align:center}
.success-box i{color:#c45824;font-size:34px;margin-bottom:14px}
.success-box h3{font-size:20px;margin-bottom:10px}
.success-box p{font-size:14px;color:#4c4a45;margin-bottom:22px}
.success-box button{padding:10px 24px;background:#1f2530;color:#fff;border:none;font-size:13.5px;cursor:pointer;border-radius:2px;font-family:inherit}

@media(max-width:960px){
.hero-grid{grid-template-columns:1fr;gap:36px}
.hero-visual{min-height:300px}
.hero-text h1{font-size:32px}
.about-grid,.mission,.contact-grid{grid-template-columns:1fr;gap:32px}
.grid-cards{grid-template-columns:repeat(2,1fr)}
.advantages{grid-template-columns:repeat(2,1fr)}
.footer-grid{grid-template-columns:1fr;gap:32px}
.list-grid{grid-template-columns:1fr}
.nav-menu{position:fixed;top:72px;right:-100%;width:78%;max-width:320px;height:calc(100vh - 72px);background:#faf7f2;flex-direction:column;align-items:flex-start;padding:28px;gap:18px;transition:right .3s ease;border-left:1px solid #e8e1d4;overflow-y:auto}
.nav-menu.open{right:0}
.nav-menu .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:8px 0 0;background:transparent;min-width:0}
.nav-menu .submenu a{padding:6px 0}
.nav-cta{display:none}
.hamburger{display:block}
.section{padding:56px 0}
.section-title{font-size:24px}
.page-hero h1{font-size:28px}
.article-title{font-size:26px}
.article-nav{grid-template-columns:1fr}
.cookie-modal{left:16px;right:16px;bottom:16px;max-width:none}
}
@media(max-width:560px){
.grid-cards{grid-template-columns:1fr}
.advantages{grid-template-columns:1fr}
.hero-text h1{font-size:27px}
}
