/* ===== krakenmagic.com shared styles ===== */
:root{
  --bg:#f5f3ee; --surface:#ffffff; --text:#23211c; --muted:#6b675d;
  --line:#e4e0d6; --accent:#1f6f5c; --accent-soft:#e1f0ea;
  --gold:#a87f29; --gold-soft:#f6edd8;
  --radius:16px; --maxw:860px; --maxw-narrow:680px;
  --shadow:0 6px 24px rgba(0,0,0,.06);
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#1a1916; --surface:#24221d; --text:#efece4; --muted:#a39e92;
    --line:#363229; --accent:#4cb89a; --accent-soft:#1d352e;
    --gold:#d6b262; --gold-soft:#33291a; --shadow:0 6px 24px rgba(0,0,0,.4); }
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Noto Sans JP",system-ui,sans-serif;background:var(--bg);color:var(--text);
  line-height:1.75;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:32px 20px 64px}
.wrap.narrow{max-width:var(--maxw-narrow)}

/* ---- top nav ---- */
.topbar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar .inner{max-width:var(--maxw);margin:0 auto;padding:10px 20px;display:flex;align-items:center;gap:14px}
.topbar .brand{font-weight:700;font-size:15px;text-decoration:none;color:var(--text);letter-spacing:.02em}
.topbar .brand span{color:var(--accent)}
.topbar nav{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
.topbar nav a{font-size:13px;color:var(--muted);text-decoration:none;padding:5px 9px;border-radius:8px}
.topbar nav a:hover{color:var(--accent);background:var(--accent-soft)}

/* ---- back link ---- */
.back{display:inline-block;font-size:13px;color:var(--accent);text-decoration:none;margin-bottom:16px}
.back:hover{text-decoration:underline}

/* ---- hero slider ---- */
.slider{position:relative;width:100%;aspect-ratio:16/7;min-height:230px;max-height:460px;
  overflow:hidden;border-radius:0 0 var(--radius) var(--radius)}
.slider .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;
  background-size:cover;background-position:center}
.slider .slide.on{opacity:1}
.slider .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,.55))}
.slider .caption{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;color:#fff;z-index:2}
.slider .caption .role{font-size:12px;letter-spacing:.12em;opacity:.9}
.slider .caption h1{font-size:clamp(22px,5vw,34px);font-weight:700;margin:4px 0 6px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.slider .caption p{font-size:clamp(13px,2.6vw,15px);max-width:560px;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.slider .dots{position:absolute;right:16px;top:16px;display:flex;gap:7px;z-index:3}
.slider .dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer;padding:0}
.slider .dots button.on{background:#fff}

/* ---- sections ---- */
section{margin-top:40px}
.cat-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--line)}
.cat-head i{font-size:22px;color:var(--accent)}
.cat-head h2{font-size:18px;font-weight:700}
.cat-head .sub{font-size:13px;color:var(--muted);margin-left:auto;font-weight:400}

/* ---- cards ---- */
.cards{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:560px){ .cards.two{grid-template-columns:1fr 1fr} }
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,box-shadow .15s}
.card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.card .ttl{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700}
.card .ttl i{font-size:20px;color:var(--accent)}
.card .meta{font-size:13px;color:var(--muted)}
.card p{font-size:14px;color:var(--text)}
.card.todo{border-style:dashed}
.note{font-size:12px;color:var(--muted);font-style:italic}

/* ---- badges & buttons ---- */
.badge{display:inline-block;font-size:11px;font-weight:500;padding:2px 10px;border-radius:999px;
  background:var(--accent-soft);color:var(--accent);align-self:flex-start}
.badge.gold{background:var(--gold-soft);color:var(--gold)}
.badge.soon{background:var(--line);color:var(--muted)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:14px;font-weight:500;
  text-decoration:none;padding:9px 16px;border-radius:10px;background:var(--accent);color:#fff;
  align-self:flex-start;transition:opacity .15s;border:none;cursor:pointer}
.btn:hover{opacity:.88}
.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.btn.gold{background:var(--gold)}
.btn.lg{font-size:16px;padding:13px 24px}
.btn.disabled{background:var(--line);color:var(--muted);pointer-events:none}
.btn-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}

/* ---- LP building blocks ---- */
.lp-hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:24px;
  background:var(--surface);border:1px solid var(--line)}
.lp-hero img{width:100%;height:auto;object-fit:cover;max-height:340px}
.lp-hero .ov{padding:22px 24px}
.lp-hero h1{font-size:clamp(22px,5vw,30px);font-weight:700;margin:8px 0}
.lp-hero .lead{font-size:15px;color:var(--muted)}
.lp-section h2{font-size:20px;font-weight:700;margin:36px 0 12px;display:flex;align-items:center;gap:8px}
.lp-section h2 i{color:var(--accent)}
.lp-section p{font-size:15px;margin-bottom:12px}
.feature-list{display:grid;gap:12px;margin:8px 0}
.feature-list .item{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;gap:12px}
.feature-list .item i{font-size:22px;color:var(--accent);flex:none;margin-top:2px}
.feature-list .item b{display:block;font-size:15px;margin-bottom:2px}
.feature-list .item span{font-size:14px;color:var(--muted)}
.steps{counter-reset:s;display:grid;gap:10px;margin:8px 0}
.steps .step{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 16px 14px 52px;position:relative}
.steps .step::before{counter-increment:s;content:counter(s);position:absolute;left:14px;top:14px;
  width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;font-size:14px}
.faq{display:grid;gap:8px;margin:8px 0}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:4px 16px}
.faq summary{cursor:pointer;font-weight:500;padding:12px 0;font-size:15px}
.faq p{padding:0 0 12px;font-size:14px;color:var(--muted)}
.cta-box{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius);
  padding:26px 24px;text-align:center;margin:36px 0}
.cta-box h3{font-size:19px;font-weight:700;margin-bottom:6px}
.cta-box p{font-size:14px;color:var(--muted);margin-bottom:16px}
.pricecards{display:grid;gap:14px;grid-template-columns:1fr}
@media(min-width:620px){.pricecards.two{grid-template-columns:1fr 1fr}}
.pricecards .pc{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.pricecards .pc .name{font-weight:700;font-size:16px}
.pricecards .pc .price{font-size:24px;font-weight:700;color:var(--accent);margin:6px 0}
.pricecards .pc .price small{font-size:13px;color:var(--muted);font-weight:400}
.pricecards .pc ul{list-style:none;font-size:13px;color:var(--muted);margin-top:8px}
.pricecards .pc li{padding:3px 0 3px 18px;position:relative}
.pricecards .pc li::before{content:"✓";position:absolute;left:0;color:var(--accent)}

/* ---- portfolio gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:640px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gallery figure{position:relative;border-radius:12px;overflow:hidden;background:var(--surface);
  border:1px solid var(--line);aspect-ratio:4/3}
.gallery figure img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:8px 10px;font-size:12px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.7))}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.lb.on{display:flex}
.lb img{max-width:100%;max-height:90vh;border-radius:8px}
.lb .x{position:absolute;top:16px;right:20px;color:#fff;font-size:34px;cursor:pointer;line-height:1}

/* ---- form ---- */
form{display:flex;flex-direction:column;gap:18px}
.field label{display:block;font-size:14px;font-weight:500;margin-bottom:6px}
.field .req{color:#c0392b;font-size:12px;margin-left:4px}
.field .hint{font-size:12px;color:var(--muted);margin-top:4px}
input,select,textarea{width:100%;font-family:inherit;font-size:15px;color:var(--text);
  background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px 12px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{min-height:90px;resize:vertical}
.row{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:520px){ .row.two{grid-template-columns:1fr 1fr} .row.three{grid-template-columns:1fr 1fr 1fr} }
.estimate{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius);padding:18px 20px}
.estimate .lbl{font-size:13px;color:var(--accent);font-weight:500}
.estimate .amt{font-size:28px;font-weight:700;color:var(--accent);margin:2px 0}
.estimate .note{font-size:12px;color:var(--muted)}
.submit{font-size:16px;font-weight:500;color:#fff;background:var(--accent);border:none;border-radius:12px;padding:14px;cursor:pointer}
.submit:hover{opacity:.9}
.submit:disabled{opacity:.6;cursor:wait}
.foot{font-size:12px;color:var(--muted);margin-top:8px;text-align:center}
.err{color:#c0392b;font-size:13px;display:none}
.ok{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius);padding:24px;text-align:center;display:none}
.ok h2{color:var(--accent);font-size:20px;margin-bottom:8px}

/* ---- admin table ---- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
table.data{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap}
table.data th,table.data td{padding:9px 12px;border-bottom:1px solid var(--line);text-align:left}
table.data th{background:var(--accent-soft);color:var(--accent);font-weight:700;position:sticky;top:0}
table.data tr:hover td{background:var(--accent-soft)}
.stat-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 18px;flex:1;min-width:120px}
.stat .n{font-size:26px;font-weight:700;color:var(--accent)}
.stat .l{font-size:12px;color:var(--muted)}

/* ---- footer ---- */
footer{margin-top:48px;text-align:center;font-size:13px;color:var(--muted);
  border-top:1px solid var(--line);padding-top:24px}
footer a{color:var(--accent);text-decoration:none}
.tagline-box{font-size:15px;color:var(--text);max-width:560px;margin:24px auto 0;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;text-align:center}

/* ===== touch-navi（画面下固定・展開メニュー：回遊用） ===== */
:root{ --tn-h:54px; }
body{ padding-bottom: calc(var(--tn-h) + env(safe-area-inset-bottom, 0px) + 8px); }
.tn-overlay{position:fixed;inset:0;background:rgba(0,0,0,.38);opacity:0;visibility:hidden;
  transition:opacity .25s;z-index:90}
.tn-overlay.on{opacity:1;visibility:visible}
.tn-bar{position:fixed;left:0;right:0;bottom:0;z-index:95;display:flex;justify-content:center;
  padding:0 0 env(safe-area-inset-bottom, 0px);pointer-events:none}
.tn-toggle{pointer-events:auto;display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#fff;border:none;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:700;letter-spacing:.02em;
  height:var(--tn-h);padding:0 26px;border-radius:16px 16px 0 0;
  box-shadow:0 -6px 24px rgba(0,0,0,.18)}
.tn-toggle .chev{transition:transform .25s}
.tn-panel.on ~ .tn-bar .tn-toggle .chev,
.tn-open .tn-toggle .chev{transform:rotate(180deg)}
.tn-toggle .gold-dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.tn-panel{position:fixed;left:0;right:0;bottom:0;z-index:96;background:var(--surface);
  border-top:1px solid var(--line);border-radius:18px 18px 0 0;box-shadow:0 -10px 40px rgba(0,0,0,.22);
  transform:translateY(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  max-height:78vh;overflow:auto;padding:10px 16px calc(20px + env(safe-area-inset-bottom,0px))}
.tn-panel.on{transform:translateY(0)}
.tn-handle{width:40px;height:4px;border-radius:2px;background:var(--line);margin:6px auto 12px}
.tn-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.tn-head b{font-size:15px}
.tn-head .x{margin-left:auto;background:none;border:none;font-size:24px;line-height:1;color:var(--muted);cursor:pointer}
.tn-cta{display:flex;gap:8px;flex-wrap:wrap;background:var(--accent-soft);border:1px solid var(--accent);
  border-radius:12px;padding:12px 14px;margin-bottom:14px;align-items:center}
.tn-cta .lbl{font-size:13px;font-weight:700;color:var(--accent);margin-right:auto}
.tn-cta a{font-size:13px;font-weight:500;text-decoration:none;background:var(--accent);color:#fff;
  padding:7px 12px;border-radius:9px}
.tn-cta a.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.tn-group{margin-bottom:12px}
.tn-group h4{font-size:12px;color:var(--muted);font-weight:700;margin:6px 2px 8px;letter-spacing:.04em}
.tn-links{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:560px){.tn-links{grid-template-columns:1fr 1fr 1fr}}
.tn-links a{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);
  background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:500}
.tn-links a:hover{border-color:var(--accent);color:var(--accent)}
.tn-links a i{font-size:17px;color:var(--accent)}

/* ===== 経歴タイムライン（about） ===== */
.draft-note{background:var(--gold-soft);border:1px solid var(--gold);color:var(--gold);
  border-radius:12px;padding:12px 16px;font-size:13px;margin-bottom:20px}
.timeline{position:relative;margin:8px 0 8px;padding-left:28px}
.timeline::before{content:"";position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:18px}
.tl-item::before{content:"";position:absolute;left:-24px;top:4px;width:12px;height:12px;border-radius:50%;
  background:var(--accent);border:2px solid var(--surface);box-shadow:0 0 0 2px var(--accent)}
.tl-item .yr{font-size:13px;font-weight:700;color:var(--accent)}
.tl-item .ttl{font-size:15px;font-weight:700;margin:1px 0 2px}
.tl-item .desc{font-size:13px;color:var(--muted)}
.tl-item .todo{color:#c0392b;font-weight:700}
.role-cards{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:620px){.role-cards{grid-template-columns:1fr 1fr}}
.role-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.role-card .rc-h{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;margin-bottom:8px}
.role-card .rc-h i{color:var(--accent);font-size:20px}
.role-card ul{list-style:none;font-size:13px}
.role-card li{padding:4px 0 4px 18px;position:relative;color:var(--text)}
.role-card li::before{content:"▸";position:absolute;left:0;color:var(--accent)}
.role-card a{font-size:13px;color:var(--accent);text-decoration:none}
