@charset "UTF-8";
/* =====================================================================
   印鑑堂ドットコム ― トップページ 高級ラグジュアリー版 (proposal)
   濃色(墨)ベース / 金(きん)・朱(しゅ)の差し色 / 明朝見出し
   ・native <details> でアコーディオン（JS不要・編集しやすい）
   ・PC/タブレット/スマホ レスポンシブ
   ===================================================================== */

:root{
  --bg:#141110;            /* 墨に近い背景      */
  --bg-2:#1b1714;
  --surface:#221c17;       /* カード面          */
  --surface-2:#2a231c;
  --line:#3b3026;          /* 罫線             */
  --line-2:#4a3c2d;
  --gold:#c8a869;          /* 金               */
  --gold-soft:#a98f57;
  --shu:#c33a2c;           /* 朱               */
  --shu-bright:#dc4636;
  --text:#f1e8d9;          /* 文字（温白）      */
  --muted:#b7aa96;
  --muted-2:#897e6c;
  --maxw:1180px;
  --pad:clamp(16px,4vw,28px);
  --radius:14px;
  --serif:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho",YuMincho,"Noto Serif JP",serif;
  --gothic:"Hiragino Kaku Gothic ProN","Yu Gothic",YuGothic,"Noto Sans JP",Meiryo,sans-serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--gothic);font-size:15px;line-height:1.8;
  letter-spacing:.02em;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;vertical-align:middle;border:0;}
a{color:inherit;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s;}
html{scroll-behavior:smooth;}
a:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.serif{font-family:var(--serif);}

/* 装飾の細い金線見出し */
.eyebrow{
  font-family:var(--serif);color:var(--gold);font-size:13px;letter-spacing:.32em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.7em;margin:0 0 .6em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);display:inline-block;}

.section{padding:clamp(44px,8vw,84px) 0;}
.section-head{text-align:center;margin-bottom:clamp(26px,5vw,46px);}
.section-head h2{
  font-family:var(--serif);font-weight:600;font-size:clamp(22px,4vw,32px);
  margin:.1em 0 .3em;letter-spacing:.06em;
}
.section-head p{color:var(--muted);margin:0;font-size:14px;}

/* ============================ トップバー ============================ */
.topbar{
  position:sticky;top:0;z-index:50;background:rgba(20,17,16,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.topbar .wrap{display:flex;align-items:center;gap:16px;height:64px;}
.brand{display:flex;align-items:baseline;gap:.5em;font-family:var(--serif);
  font-size:22px;font-weight:700;letter-spacing:.14em;color:var(--text);}
.brand .dot{color:var(--shu);}
.brand small{font-family:var(--gothic);font-size:10px;letter-spacing:.3em;color:var(--gold);}
.topnav{margin-left:auto;display:flex;align-items:center;gap:22px;font-size:13px;color:var(--muted);}
.topnav a:hover{color:var(--gold);}
.topnav .util{display:flex;gap:14px;}
.btn{
  display:inline-flex;align-items:center;gap:.5em;font-size:13px;font-weight:700;
  padding:9px 18px;border-radius:999px;border:1px solid var(--line-2);color:var(--text);
  letter-spacing:.06em;white-space:nowrap;
}
.btn:hover{border-color:var(--gold);color:var(--gold);}
.btn-shu{background:var(--shu);border-color:var(--shu);color:#fff;}
.btn-shu:hover{background:var(--shu-bright);border-color:var(--shu-bright);color:#fff;transform:translateY(-1px);}
.btn-gold{background:linear-gradient(180deg,#d9bd80,#c8a869);border-color:var(--gold);color:#241c12;}
.btn-gold:hover{filter:brightness(1.06);transform:translateY(-1px);color:#241c12;}
.topnav .util a.btn{padding:7px 14px;}
.menu-toggle{display:none;}

/* ============================ ヒーロー ============================ */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(1200px 500px at 75% -10%,rgba(200,168,105,.16),transparent 60%),
    linear-gradient(180deg,#1a1512,#141110);
  border-bottom:1px solid var(--line);
}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,5vw,56px);
  align-items:center;padding-top:clamp(40px,7vw,80px);padding-bottom:clamp(40px,7vw,80px);}
.hero-copy h1{font-family:var(--serif);font-weight:700;
  font-size:clamp(30px,6vw,54px);line-height:1.28;letter-spacing:.04em;margin:.2em 0 .5em;}
.hero-copy h1 .shu{color:var(--shu);}
.hero-copy h1 .gold{color:var(--gold);}
.hero-lead{color:var(--muted);font-size:clamp(14px,2vw,16px);max-width:30em;margin:0 0 1.6em;}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:1.6em;}
.hero-cta .btn{padding:13px 26px;font-size:14px;}
.hero-note{display:flex;flex-wrap:wrap;gap:8px 20px;font-size:12.5px;color:var(--muted-2);}
.hero-note b{color:var(--gold);font-weight:700;}
.hero-art{position:relative;display:flex;justify-content:center;align-items:center;}
/* 朱印（はんこの押印）モチーフ ― 画像不要で高精細・ブランド性◎ */
.seal-imp{position:relative;width:min(330px,74vw);aspect-ratio:1;border-radius:22px;
  background:radial-gradient(130% 130% at 28% 18%,#d9472f,#a82217);
  display:grid;place-content:center;transform:rotate(-3deg);
  box-shadow:0 34px 70px -28px rgba(180,40,30,.7),
             inset 0 0 0 7px rgba(255,255,255,.08),
             inset 0 0 0 8px rgba(200,168,105,.55);}
.seal-imp .seal-char{font-family:var(--serif);color:#fff;font-weight:700;text-align:center;
  font-size:clamp(54px,12vw,92px);line-height:1.08;text-shadow:0 3px 14px rgba(0,0,0,.3);}
.seal-imp::after{content:"";position:absolute;inset:7px;border-radius:15px;
  background:radial-gradient(75% 75% at 72% 82%,transparent 56%,rgba(60,10,6,.3));mix-blend-mode:multiply;}
.hero-badge{position:absolute;top:-2px;right:14%;z-index:3;
  background:linear-gradient(180deg,#d9bd80,#c8a869);color:#241c12;font-weight:700;
  font-size:12px;letter-spacing:.08em;padding:7px 15px;border-radius:999px;
  box-shadow:0 12px 22px -8px rgba(0,0,0,.6);transform:rotate(5deg);}

/* ============================ 信頼バー ============================ */
.trust{background:var(--bg-2);border-bottom:1px solid var(--line);}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:0;}
.trust .item{flex:1 1 0;min-width:150px;text-align:center;padding:18px 14px;
  border-left:1px solid var(--line);}
.trust .item:first-child{border-left:0;}
.trust .item b{display:block;font-family:var(--serif);color:var(--gold);font-size:15px;letter-spacing:.04em;}
.trust .item span{font-size:11.5px;color:var(--muted);}

/* ============================ カテゴリーカード ============================ */
.cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2.4vw,22px);}
.cat-card{position:relative;display:block;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;background:var(--surface);min-height:230px;}
.cat-card .ph{position:absolute;inset:0;}
.cat-card .ph img{width:100%;height:100%;object-fit:cover;opacity:.62;transition:transform .5s,opacity .3s;}
.cat-card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,17,16,.15) 25%,rgba(20,17,16,.92));}
.cat-card .body{position:relative;z-index:2;height:100%;min-height:230px;display:flex;
  flex-direction:column;justify-content:flex-end;padding:20px 22px;}
.cat-card .en{font-family:var(--serif);font-size:11px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;}
.cat-card h3{font-family:var(--serif);font-weight:700;font-size:20px;letter-spacing:.06em;margin:.15em 0 .35em;}
.cat-card .price{color:var(--text);font-size:13px;}
.cat-card .price b{font-size:20px;color:#fff;font-family:var(--serif);}
.cat-card .price .shu{color:var(--shu-bright);}
.cat-card .go{margin-top:.7em;font-size:12px;color:var(--gold);letter-spacing:.1em;display:inline-flex;gap:.5em;align-items:center;}
.cat-card .go::after{content:"→";transition:transform .25s;}
.cat-card:hover{border-color:var(--gold);transform:translateY(-5px);box-shadow:0 26px 44px -26px rgba(0,0,0,.75);}
.cat-card:hover .ph img{transform:scale(1.06);opacity:.72;}
.cat-card:hover .go::after{transform:translateX(5px);}

/* 小さめカード（メーカー等） */
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px;}
.mini{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:12px;
  background:var(--surface);padding:14px 16px;}
.mini img{width:56px;height:42px;object-fit:contain;background:#fff;border-radius:6px;padding:3px;}
.mini b{font-size:13px;}
.mini span{display:block;font-size:11px;color:var(--muted);}
.mini:hover{border-color:var(--gold);}

/* ============================ 印材鑑定 ============================ */
.kantei{background:linear-gradient(180deg,#1d1813,#141110);border-block:1px solid var(--line);}
.kantei .inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,48px);align-items:center;}
.kantei h2{font-family:var(--serif);font-size:clamp(22px,3.6vw,30px);font-weight:600;margin:.2em 0 .4em;letter-spacing:.05em;}
.kantei p{color:var(--muted);margin:0 0 1em;font-size:14px;}
.kantei .form-card{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);
  padding:24px 26px;box-shadow:0 24px 50px -30px rgba(0,0,0,.8);}
/* 同梱フォーム(年→鑑定)の中身を上品に */
.kantei form{display:flex;flex-wrap:wrap;align-items:center;gap:10px;}
.kantei select{background:var(--bg-2);color:var(--text);border:1px solid var(--line-2);
  border-radius:8px;padding:11px 12px;font-size:15px;font-family:var(--gothic);min-width:110px;}
.kantei input[type=submit]{background:var(--shu);color:#fff;border:0;border-radius:999px;
  padding:11px 26px;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.08em;}
.kantei input[type=submit]:hover{background:var(--shu-bright);}
.kantei table{border:0;}.kantei td{padding:2px 4px;}

/* ============================ アコーディオン (details) ============================ */
.acc{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);
  margin:14px 0;overflow:hidden;}
.acc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:14px;
  padding:18px 22px;font-family:var(--serif);font-size:17px;letter-spacing:.06em;color:var(--text);}
.acc>summary::-webkit-details-marker{display:none;}
.acc>summary .ic{margin-left:auto;width:26px;height:26px;border:1px solid var(--gold-soft);
  border-radius:50%;color:var(--gold);display:grid;place-content:center;position:relative;flex:none;transition:transform .3s;}
.acc>summary .ic::before,.acc>summary .ic::after{content:"";position:absolute;top:50%;left:50%;background:var(--gold);}
.acc>summary .ic::before{width:11px;height:1.5px;transform:translate(-50%,-50%);}
.acc>summary .ic::after{width:1.5px;height:11px;transform:translate(-50%,-50%);transition:transform .3s;}
.acc[open]>summary .ic::after{transform:translate(-50%,-50%) scaleY(0);}
.acc>summary .tag{font-family:var(--gothic);font-size:11px;color:var(--muted-2);letter-spacing:.04em;}
.acc[open]>summary{border-bottom:1px solid var(--line);color:var(--gold);}
.acc .acc-body{padding:6px 22px 22px;}

/* カテゴリーナビ（アコーディオン内） */
.navcols{columns:3;column-gap:30px;}
.navgroup{break-inside:avoid;margin-bottom:18px;}
.navgroup h4{font-family:var(--serif);color:var(--gold);font-size:14px;letter-spacing:.08em;
  margin:0 0 .5em;padding-bottom:.4em;border-bottom:1px solid var(--line);}
.navgroup ul{list-style:none;margin:0;padding:0;}
.navgroup li{margin:.18em 0;}
.navgroup a{color:var(--muted);font-size:13.5px;display:inline-block;padding:2px 0;}
.navgroup a:hover{color:var(--gold);padding-left:4px;}
.navgroup .sub{color:var(--muted-2);font-size:11px;letter-spacing:.1em;margin:.6em 0 .2em;}

/* お買い物ガイド */
.guide-cols{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.guide-cols h4{font-family:var(--serif);color:var(--gold);font-size:15px;margin:0 0 .5em;}
.guide-cols p{font-size:13px;color:var(--muted);margin:.2em 0 1em;}
.pay-table{width:100%;border-collapse:collapse;font-size:13px;}
.pay-table th,.pay-table td{border:1px solid var(--line-2);padding:9px 10px;text-align:center;}
.pay-table th{background:var(--surface-2);color:var(--gold);font-weight:600;}
.pay-table .free{color:var(--shu-bright);font-weight:700;}
.guide-cols a{color:var(--gold);}

/* ============================ フッター ============================ */
.foot{background:var(--bg-2);border-top:1px solid var(--line);padding:clamp(36px,6vw,60px) 0 28px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;margin-bottom:30px;}
.foot .brand{font-size:20px;margin-bottom:.4em;}
.foot address{font-style:normal;color:var(--muted);font-size:13px;line-height:1.9;}
.foot h5{font-family:var(--serif);color:var(--gold);font-size:13px;letter-spacing:.1em;margin:0 0 .7em;}
.foot ul{list-style:none;margin:0;padding:0;font-size:13px;}
.foot li{margin:.3em 0;}
.foot a{color:var(--muted);}
.foot a:hover{color:var(--gold);}
.foot .pay-logos{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px;}
.foot .pay-logos span{font-size:11px;color:var(--muted-2);border:1px solid var(--line-2);
  border-radius:5px;padding:3px 8px;letter-spacing:.06em;}
.foot-bottom{border-top:1px solid var(--line);padding-top:20px;text-align:center;
  font-size:11.5px;color:var(--muted-2);letter-spacing:.04em;}
.foot-bottom a{color:var(--muted);}

/* ============================ レスポンシブ ============================ */
@media (max-width:900px){
  .hero .wrap{grid-template-columns:1fr;}
  .hero-art{order:-1;max-width:440px;}
  .kantei .inner{grid-template-columns:1fr;}
  .cats-grid{grid-template-columns:repeat(2,1fr);}
  .mini-grid{grid-template-columns:repeat(2,1fr);}
  .navcols{columns:2;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .topnav .links{display:none;}
}
@media (max-width:560px){
  body{font-size:14px;}
  .topbar .wrap{height:56px;gap:10px;}
  .brand{font-size:18px;flex:1 1 auto;min-width:0;overflow:hidden;white-space:nowrap;}
  .topnav{gap:10px;flex-shrink:0;}
  .brand small{display:none;}
  .topnav .util{gap:7px;}
  .topnav .util a.btn{padding:6px 10px;font-size:12px;letter-spacing:0;}
  .topnav .util a.btn:first-child{display:none;}   /* スマホはログインを隠し 会員登録+カート を優先 */
  .cats-grid{grid-template-columns:1fr;}
  .cat-card{min-height:200px;}
  .cat-card .body{min-height:200px;}
  .navcols{columns:1;}
  .guide-cols{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
  .trust .item{flex-basis:50%;border-top:1px solid var(--line);}
  .trust .item:nth-child(-n+2){border-top:0;}
}
