/* Polaris site-wide styles — Notion-inspired light theme
 * Shared by help / terms / privacy / tokutei pages.
 * (index.html and glossary/ have their own component styles on top of the same tokens.)
 */

:root {
    --bg: #ffffff;
    --bg-warm: #f7f6f3;
    --surface: #ffffff;
    --ink: #191919;
    --ink-warm: #37352f;
    --ink-soft: #787774;
    --ink-mute: #9b9a97;
    --line: #e9e9e7;
    --accent: #2383e2;
    --mark: #fdecc8;
    --callout-bg: #f1f1ef;
    --callout-blue: #e7f3f8;
    --callout-yellow: #fdecc8;
    --callout-red: #fbe4e4;
    --font-serif: "Noto Serif JP", ui-serif, "Lyon Text", Georgia, serif;
    --font-sans: -apple-system, BlinkMacSystemFont, "Inter", "Noto Sans JP", "Helvetica Neue", sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;
}

* { -webkit-font-smoothing: antialiased; }
html { font-feature-settings: "palt" 1; scroll-behavior: smooth; }
body {
    font-family: var(--font-sans);
    color: var(--ink);
    background: var(--bg);
    font-size: 16px;
    line-height: 1.8;
}
h1, h2, h3, h4 {
    font-family: var(--font-serif);
    color: var(--ink-warm);
    line-height: 1.3;
    font-weight: 500;
}
p { color: var(--ink-warm); }
a { color: var(--accent); text-underline-offset: 3px; }

.mono { font-family: var(--font-mono); }
.mark {
    background: linear-gradient(transparent 60%, var(--mark) 60%);
    padding: 0 2px;
}
.hairline { border-top: 1px solid var(--line); }

.cat-label {
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-mute);
}

/* トップナビ（sticky） */
.top-nav {
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    position: sticky;
    top: 0;
    z-index: 40;
}
.top-nav-inner {
    max-width: 1152px;
    margin: 0 auto;
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    font-size: 14px;
}
.nav-link {
    color: var(--ink-soft);
    text-decoration: none;
    font-size: 14px;
}
.nav-link:hover { color: var(--ink); }

/* ページヘッダー（serif タイトル） */
.page-header {
    max-width: 820px;
    margin: 0 auto;
    padding: 80px 24px 48px;
}
.page-header .section-tag {
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 16px;
}
.page-title {
    font-family: var(--font-serif);
    font-size: clamp(2.25rem, 5vw, 3.2rem);
    letter-spacing: -0.01em;
    font-weight: 500;
    color: var(--ink-warm);
    margin-bottom: 12px;
    line-height: 1.2;
}
.page-lead {
    color: var(--ink-soft);
    font-size: 17px;
    line-height: 1.75;
}

/* 区切り線 */
.page-rule {
    max-width: 820px;
    margin: 0 auto;
    padding: 0 24px;
}

/* メイン本文レイアウト */
.page-main {
    max-width: 820px;
    margin: 0 auto;
    padding: 32px 24px 80px;
}

/* セクション（条文・ヘルプ各項目） */
.doc-section { margin-bottom: 56px; }
.doc-section:last-child { margin-bottom: 0; }
.doc-section h2 {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--ink-warm);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--line);
}
.doc-section h3 {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--ink);
    margin: 20px 0 8px;
}
.doc-section p {
    color: var(--ink-warm);
    font-size: 15.5px;
    line-height: 1.85;
    margin-bottom: 10px;
}
.doc-section ul, .doc-section ol {
    color: var(--ink-warm);
    font-size: 15.5px;
    line-height: 1.85;
    padding-left: 0;
    list-style: none;
}
.doc-section ul li {
    padding-left: 20px;
    position: relative;
    margin-bottom: 6px;
}
.doc-section ul li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 13px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--ink-mute);
}
.doc-section ol {
    counter-reset: orderedlist;
}
.doc-section ol li {
    padding-left: 28px;
    position: relative;
    margin-bottom: 6px;
    counter-increment: orderedlist;
}
.doc-section ol li::before {
    content: counter(orderedlist) ".";
    position: absolute;
    left: 0;
    top: 0;
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--ink-mute);
}
.doc-section .note {
    color: var(--ink-soft);
    font-size: 13.5px;
    line-height: 1.7;
}
.doc-section .sub {
    margin-left: 16px;
}

/* コールアウト（先頭の導入文など） */
.callout {
    background: var(--bg-warm);
    border-left: 2px solid var(--ink-mute);
    padding: 20px 24px;
    border-radius: 0 6px 6px 0;
    margin-bottom: 40px;
}
.callout p { color: var(--ink-warm); font-size: 15px; line-height: 1.9; margin: 0; }

/* 付則ボックス */
.appendix {
    background: var(--bg-warm);
    padding: 18px 22px;
    border-radius: 8px;
    margin-top: 40px;
}
.appendix p {
    font-family: var(--font-mono);
    font-size: 12.5px;
    color: var(--ink-soft);
    margin: 0;
    line-height: 1.8;
}

/* カード */
.card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 28px;
    transition: border-color 0.2s ease;
}
.card:hover { border-color: var(--ink-mute); }

/* アコーディオン（help.html用） */
details.accordion {
    border: 1px solid var(--line);
    border-radius: 10px;
    margin-bottom: 10px;
    background: var(--surface);
    transition: border-color 0.2s ease;
    overflow: hidden;
}
details.accordion[open] { border-color: var(--ink-mute); }
details.accordion summary {
    list-style: none;
    cursor: pointer;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--ink-warm);
    transition: background 0.2s;
}
details.accordion summary::-webkit-details-marker { display: none; }
details.accordion summary:hover { background: var(--bg-warm); }
details.accordion summary::after {
    content: '+';
    font-family: var(--font-mono);
    font-size: 1.25rem;
    color: var(--ink-mute);
    transition: transform 0.2s, color 0.2s;
    flex-shrink: 0;
}
details.accordion[open] summary::after { content: '−'; color: var(--ink); }
.accordion-body {
    padding: 4px 24px 24px;
    border-top: 1px solid var(--line);
    color: var(--ink-warm);
    font-size: 15px;
    line-height: 1.85;
}
.accordion-body h3 {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--ink);
    margin: 18px 0 8px;
}
.accordion-body p { margin-bottom: 12px; color: var(--ink-warm); }
.accordion-body ul {
    padding-left: 0;
    list-style: none;
    margin-bottom: 12px;
}
.accordion-body ul li {
    padding-left: 20px;
    position: relative;
    margin-bottom: 6px;
}
.accordion-body ul li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 12px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--ink-mute);
}
.accordion-body ol { padding-left: 24px; margin-bottom: 12px; }
.accordion-body .small { color: var(--ink-soft); font-size: 13.5px; line-height: 1.7; }
.accordion-body strong { color: var(--ink); font-weight: 600; }

/* コードブロック（プロンプト） */
.code-block {
    background: var(--bg-warm);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 18px 20px;
    margin: 12px 0;
    font-family: var(--font-mono);
    font-size: 13px;
    line-height: 1.8;
    color: var(--ink-warm);
    white-space: pre-wrap;
    overflow-x: auto;
}

/* ボタン */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 8px;
    font-weight: 500;
    text-decoration: none;
    transition: opacity .2s, background .2s, border-color .2s, transform .2s;
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: 14px;
    background: var(--surface);
    color: var(--ink);
    border: 1px solid var(--line);
}
.btn:hover { border-color: var(--ink-mute); transform: translateY(-1px); }
.btn-primary {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink);
}
.btn-primary:hover { opacity: 0.85; border-color: var(--ink); }
.btn-copied {
    background: var(--ink-warm);
    color: #fff;
    border-color: var(--ink-warm);
}

/* 警告・強調 */
.alert-danger {
    background: var(--callout-red);
    padding: 14px 18px;
    border-radius: 8px;
    color: #7f1d1d;
    font-weight: 600;
    font-size: 14.5px;
}

/* フッター */
.site-footer {
    max-width: 1152px;
    margin: 0 auto;
    padding: 56px 24px;
    text-align: center;
    border-top: 1px solid var(--line);
}
.site-footer .company {
    color: var(--ink-warm);
    font-size: 15px;
    margin-bottom: 6px;
}
.site-footer .contact {
    font-size: 13.5px;
    color: var(--ink-soft);
    margin-bottom: 24px;
}
.site-footer .footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px 24px;
    margin-bottom: 24px;
}
.site-footer a.footer-link {
    color: var(--ink-soft);
    text-decoration: none;
    font-size: 13.5px;
}
.site-footer a.footer-link:hover { color: var(--ink); text-decoration: underline; }
.site-footer .copy {
    font-family: var(--font-mono);
    font-size: 11.5px;
    color: var(--ink-mute);
    margin-top: 16px;
}
