/* ===========================================================
   OMAMORI Final v8 / MASTER ? Brand / Trust / Conversion / Mobile / A11y
   =========================================================== */

/* Reset / base */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:#FAF7F0;color:#1E1E1E;
  font-family:"Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.9}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:.25s ease}
small,.small{font-size:.9rem}
:root{
  --paper:#FAF7F0; --ink:#1E1E1E;
  --pine:#124C44; --pine-2:#0F3E38; --brass:#B48C40; --suzu:#8B928C;
  --card:#fff; --muted:#f3efe7; --radius:18px; --shadow:0 10px 30px rgba(10,20,20,.08);
}

/* Containers */
.container{max-width:1160px;margin:0 auto;padding:0 16px}
.section{padding:56px 0}
.section.tight{padding:36px 0}
.center{text-align:center}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}

/* Header?Brand bar??????? */
.header-wrap{position:sticky;top:0;z-index:100;background:#fff;
  border-bottom:1px solid rgba(0,0,0,.06);backdrop-filter:saturate(140%) blur(6px)}
.header-wrap.scrolled{box-shadow:0 6px 16px rgba(10,20,18,.06)}
.header-inner{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;
  max-width:1160px;margin:0 auto;padding:10px 16px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:28px;width:auto;object-fit:contain;display:block}
.brand .brand-name{font-family:"Shippori Mincho",serif;font-weight:700;font-size:18px;color:var(--pine);white-space:nowrap}
.brand--lockup .brand-name{display:none} /* ???????????????? */

/* ????????PC?????? */
.nav-toggle{display:none;border:0;background:transparent;color:var(--pine);font-size:24px}
.main-nav{display:flex;flex-wrap:nowrap;gap:12px;justify-content:flex-end;align-items:center}
.main-nav a{
  padding:6px 10px;border-radius:10px;color:var(--pine);font-weight:600;
  font-size:.92rem;white-space:nowrap;letter-spacing:.01em;line-height:1.2;
}
.main-nav a:hover{background:rgba(180,140,64,.12)}
.main-nav a.is-active{background:rgba(180,140,64,.14)}
@media (min-width:1280px){ .brand img{height:32px} }
@media (max-width:960px){
  .header-inner{grid-template-columns:1fr auto}
  .nav-toggle{display:block}
  .main-nav{display:none;position:absolute;top:60px;left:0;right:0;background:#fff;
    border-bottom:1px solid rgba(0,0,0,.06);padding:12px 16px;flex-direction:column;align-items:flex-start;flex-wrap:wrap}
  .main-nav.open{display:flex}
}

/* Hero?assets/hero.jpg??????? */
.hero{position:relative;min-height:60vh;display:flex;align-items:center;
  background:url('assets/hero.jpg') center/cover no-repeat}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,76,68,.45),rgba(18,76,68,.15))}
.hero-inner{position:relative;z-index:1}
.hero h1{font-family:"Shippori Mincho",serif;color:#fff;font-size:clamp(28px,5vw,44px);
  line-height:1.25;text-shadow:0 2px 6px rgba(0,0,0,.30)}
.hero p.lead{color:#eaf0ed;margin-top:10px}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

/* Buttons???hover???????? */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:12px;
  background:linear-gradient(180deg,var(--pine),var(--pine-2));
  color:#fff;font-weight:700;box-shadow:0 6px 16px rgba(0,0,0,.06);
  transition:.25s ease; transform:translateY(0);
}
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0); box-shadow:0 3px 10px rgba(0,0,0,.08);}
.btn:focus-visible{outline:none;box-shadow:0 0 0 6px rgba(180,140,64,.18)}

.btn-outline{
  background:#fff;color:var(--pine);border:1px solid var(--pine);
  display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;
  transition:.25s ease; transform:translateY(0);
}
.btn-outline:hover{
  background:linear-gradient(180deg,var(--pine),var(--pine-2));
  color:#fff;border-color:var(--pine); transform:translateY(-1px);
}
.btn-outline:active{ transform:translateY(0); box-shadow:0 3px 10px rgba(0,0,0,.08); }

/* Badges */
.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#F4EFE3;color:var(--pine);
  border:1px solid rgba(18,76,68,.18);font-size:.86rem;font-weight:700}
.badge--hot{ background:var(--pine); color:#fff; border-color:var(--pine); }

/* Typography??????????? */
.h-title{
  font-family:"Shippori Mincho",serif;font-weight:700;color:var(--pine);
  font-size:clamp(22px,3.6vw,28px);display:inline-block;padding-bottom:4px;margin-bottom:12px;
  background:linear-gradient(transparent 60%, rgba(180,140,64,.18) 0);
}
.lead{color:var(--ink);opacity:.95}

/* Cards & grids */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1200px){.grid-4{grid-template-columns:repeat(3,1fr)}}
@media (max-width:800px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.grid-4{grid-template-columns:1fr}}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.card h3{font-family:"Shippori Mincho",serif;font-size:18px;color:var(--pine);margin-bottom:6px}

/* Makers as chips */
.makers{display:flex;flex-wrap:wrap;gap:8px 10px;list-style:none;padding:0;margin:8px 0 4px}
.makers li{background:#fff;border:1px solid rgba(18,76,68,.18);border-radius:999px;padding:6px 10px;color:var(--ink);font-size:.92rem}

/* Campaign blocks */
.campaign{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:18px;margin:18px 0}
.campaign h3{margin-bottom:6px}
.campaign .notes{font-size:.92rem;color:#6b716c}

/* Footer */
footer{margin-top:56px;background:#fff;border-top:1px solid rgba(0,0,0,.06);text-align:center;padding:22px;color:#6b716c;font-size:14px}
.disclaimer{display:none}

/* Contact */
.form-wrap{max-width:760px;margin:0 auto}
.form-embed{position:relative;padding-top:62%}
.form-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.form-fallback{display:none}
.form-fallback.show{display:block}

/* ===============================================
   Mobile Tuning Pack??????????PC?????
   =============================================== */
@media (max-width: 768px){
  .brand img{ height:24px; }
  .main-nav{ gap:10px; }
  .main-nav a{ font-size:1rem; padding:10px 12px; }
  .hero{ min-height:56vh; }
  .hero h1{ font-size:28px; line-height:1.3; }
  .hero p.lead{ font-size:14px; line-height:1.85; }
  .hero-ctas a{ width:100%; justify-content:center; }
  .section{ padding:40px 0; }
  .card{ padding:16px; }
  .h-title{ font-size:22px; }
  .lead{ font-size:15px; }
  .grid-4,.grid-3{ grid-template-columns:1fr; }
  .makers{ gap:8px; }
  .makers li{ padding:6px 8px; font-size:.9rem; }
  .btn,.btn-outline{ padding:14px 16px; font-size:1rem; }
}
@media (max-width: 480px){
  .main-nav a{ font-size:.98rem; }
  .hero h1{ font-size:26px; }
  .hero p.lead{ font-size:13.5px; }
  .section{ padding:36px 0; }
  .card{ padding:14px; }
}

/* A11y: reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}
