@charset "UTF-8";

/* ==========================================================================
   1. 変数定義 (CSS Variables)
   ========================================================================== */
:root {
    /* ブランドカラー */
    --primary-color: #66ba6b;
    --primary-color-hover: #57a85c;
    --primary-color-active: #4e9a53;
    --primary-color-light: rgba(102, 186, 107, 0.15);
    --accent-green: #32d296;

    /* ライトモード用 (Default) */
    --bg-color: #f8f9fa;
    --card-bg: #ffffff;
    --text-color: #333333;
    --mute-text: #666666;
    --border-color: #e5e5e5;
}

[data-theme='dark'] {
    /* ダークモード用 */
    --bg-color: #121212;
    --card-bg: #1e1e1e;
    --text-color: #e0e0e0;
    --mute-text: #b0b0b0;
    --border-color: #333333;
}

/* ==========================================================================
   2. ベーススタイル
   ========================================================================== */
body {
    background-color: var(--bg-color) !important;
    color: var(--text-color);
    font-family: 'Noto Sans JP', sans-serif;
    transition: background-color 0.3s, color 0.3s;
}

h1, .uk-h1, h2, .uk-h2, h3, .uk-h3, h4, .uk-h4, .uk-button, .uk-navbar-nav > li > a {
    text-transform: none !important;
}

a {
    color: var(--primary-color);
    transition: 0.2s;
}

a:hover {
    color: var(--primary-color-hover);
    text-decoration: none;
}

/* ==========================================================================
   3. UIkit コンポーネント上書き
   ========================================================================== */

/* カード */
.uk-card-default {
    background-color: var(--card-bg) !important;
    color: var(--text-color) !important;
    border: 1px solid var(--border-color);
}

.uk-card-title, h1, h2, h3, h4 {
    color: var(--text-color) !important;
}

.uk-card-secondary .uk-card-title, 
.uk-card-secondary h1, 
.uk-card-secondary h2, 
.uk-card-secondary h3, 
.uk-card-secondary h4 {
    color: white !important;
}

/* プライマリボタン */
.uk-button-primary ,
.uk-card-primary.uk-card-body .uk-button-primary, .uk-card-primary>:not([class*=uk-card-media]) .uk-button-primary, .uk-card-secondary.uk-card-body .uk-button-primary, .uk-card-secondary>:not([class*=uk-card-media]) .uk-button-primary, .uk-light .uk-button-primary, .uk-offcanvas-bar .uk-button-primary, .uk-overlay-primary .uk-button-primary, .uk-section-primary:not(.uk-preserve-color) .uk-button-primary, .uk-section-secondary:not(.uk-preserve-color) .uk-button-primary, .uk-tile-primary:not(.uk-preserve-color) .uk-button-primary, .uk-tile-secondary:not(.uk-preserve-color) .uk-button-primary {
    background-color: var(--primary-color)!important;
    color: #fff !important;
    border: none;
    text-align: center;
}

.uk-button-primary:hover, .uk-button-primary:focus,
.uk-card-primary.uk-card-body .uk-button-primary, .uk-card-primary>:not([class*=uk-card-media]) .uk-button-primary, .uk-card-secondary.uk-card-body .uk-button-primary, .uk-card-secondary>:not([class*=uk-card-media]) .uk-button-primary, .uk-light .uk-button-primary, .uk-offcanvas-bar .uk-button-primary, .uk-overlay-primary .uk-button-primary, .uk-section-primary:not(.uk-preserve-color) .uk-button-primary, .uk-section-secondary:not(.uk-preserve-color) .uk-button-primary, .uk-tile-primary:not(.uk-preserve-color) .uk-button-primary, .uk-tile-secondary:not(.uk-preserve-color) .uk-button-primary {
    background-color: var(--primary-color-hover)!important;
    color: #fff !important;
}

.uk-button-primary:active {
    background-color: var(--primary-color-active);
}

.uk-card-primary.uk-card-body .uk-nav-default>li>a, .uk-card-primary>:not([class*=uk-card-media]) .uk-nav-default>li>a, .uk-card-secondary.uk-card-body .uk-nav-default>li>a, .uk-card-secondary>:not([class*=uk-card-media]) .uk-nav-default>li>a, .uk-light .uk-nav-default>li>a, .uk-offcanvas-bar .uk-nav-default>li>a, .uk-overlay-primary .uk-nav-default>li>a, .uk-section-primary:not(.uk-preserve-color) .uk-nav-default>li>a, .uk-section-secondary:not(.uk-preserve-color) .uk-nav-default>li>a, .uk-tile-primary:not(.uk-preserve-color) .uk-nav-default>li>a, .uk-tile-secondary:not(.uk-preserve-color) .uk-nav-default>li>a {
    color: rgba(255, 255, 255, 1);
}

.uk-text-primary {
    color: var(--primary-color)!important;
}

/* ナビゲーション */
.uk-navbar-container:not(.uk-navbar-transparent) {
  /
  /*  background: var(--card-bg) !important; */
    border-bottom: 1px solid var(--border-color);
}

.uk-navbar-nav > li > a {
    min-height: 10px;
    padding: 4px 12px;
}

.uk-navbar-nav > li > a:not(.uk-button) {
    color: var(--text-color) !important;
}

/* パンくず */
.uk-breadcrumb > :last-child > span, 
.uk-breadcrumb > :last-child > a:not([href]) {
    color: var(--text-color) !important;
}

/* フォーム */
.uk-input, .uk-textarea, .uk-select {
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
    border-color: var(--border-color) !important;
}

.uk-alert-warning {
    background-color: rgba(241, 255, 222, 0.9);
    background-image: initial;
    background-position-x: initial;
    background-position-y: initial;
    background-size: initial;
    background-repeat: initial;
    background-attachment: initial;
    background-origin: initial;
    background-clip: initial;
    color: #444444;
    border-radius: 4px;
    border: solid 1px #444444;
}

[data-theme='dark'] .uk-alert-warning {
    background-color: rgba(0, 0, 0, 0.7)!important;
    color: #aaaa00!important;
    border: solid 1px #444444!important;
}

.uk-notification-message {
    color: #333;
    background: #f8f8aa;
    font-size: 14px;
    white-space: nowrap;
    border: 4px solid #dfdf44;
    border-radius: 20px;
    text-align: center;
}

.offcanvas-menu-button {
    background: #666;
    height:24px; margin: 2px 0 2px 0; padding: 2px 20px; text-align: center!important"
}

.uk-offcanvas-bar .point-badge-div {
    background: #666;
    width: 100%;
    color: #fff
}
.uk-offcanvas-bar .point-badge-div a {
    color: #fff
}
.uk-button.uk-button-default.uk-border-rounded {
    background: #333;
    color: #fff;
}
.button-cancel.uk-button.uk-button-default.uk-border-rounded {
    background-color: white!important;
    color: #555;
}

.button-lang.uk-button.uk-button-default.uk-border-rounded {
    background:  white!important;
    color: #555;
}  

.uk-navbar-nav>li>a.uk-button.uk-button-primary,
.uk-navbar-nav>li>a.uk-button.uk-button-secondary
 {
    color: #fff;
}
.uk-navbar-item, .uk-navbar-nav>li>a, .uk-navbar-toggle {
    padding: 4px 24px;
}


/* ==========================================================================
   4. オリジナルクラス
   ========================================================================== */
.tool-header-meta {
    margin-bottom: 30px;
    border-left: 5px solid var(--accent-green);
    padding-left: 15px;
}

.tool-card {
    transition: transform 0.2s, box-shadow 0.2s;
    border: 1px solid var(--border-color);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.tool-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.icon-circle {
    width: 50px;
    height: 50px;
    min-width: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 10px;
}

.point-badge-div.uk-button {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    box-shadow: 0 6px 18px rgba(0,0,0,.06);
    font-size: 13px;
    color: var(--text-color);
}

.more-rounded { border-radius: 20px; }
.hidden { display: none !important; }

.ivy-menu {
    width: 100%;
    white-space: nowrap;
}

.notice {
    color: #666;
    background: #fefedf;
    font-size: 14px;
    white-space: nowrap;
    border: 1px solid #dfdf44;
    border-radius: 4px;
    text-align: center;
    margin: 10px;
    padding: 4px;
    width: 650px;
    max-width: 90%;
}

.dropZone {
    border:4px dashed #60cd6e; background:#fff; cursor:pointer;
    border-radius: 20px;
}
[data-theme='dark'] .dropZone {
    border:4px dashed #60cd6e; background:#444; cursor:pointer;
}


/* ==========================================================================
   5. ダークモード専用微調整
   ========================================================================== */
[data-theme='dark'] .uk-logo { color: var(--accent-green); }
[data-theme='dark'] .uk-search-input { background: #2a2a2a !important; }
[data-theme='dark'] .uk-offcanvas-bar { background: #1e1e1e; }
[data-theme='dark'] .uk-button-text { color: var(--accent-green); }
[data-theme='dark'] .uk-section-muted { background: var(--bg-color); }
[data-theme='dark'] .uk-button-default { border-color: var(--border-color); color: #fff; }

/* テーブル(ダークモード) */
[data-theme='dark'] .uk-table { background-color: var(--card-bg) !important; color: var(--text-color) !important; }
[data-theme='dark'] .uk-table th { background: #2a2a2a !important; color: var(--text-color) !important; }
[data-theme='dark'] .uk-table-striped tbody tr:nth-of-type(even) { background-color: rgba(255, 255, 255, 0.03) !important; }

/* 年号ハイライト(ダークモード) */
[data-theme='dark'] .highlight-rewa { background-color: #3d1a1a !important; }
[data-theme='dark'] .highlight-heisei { background-color: #1a263d !important; }

[data-theme='dark'] .uk-table-striped tbody tr:nth-of-type(odd), .uk-table-striped>tr:nth-of-type(odd) {
    background: #3d1a1a !important; }
}


.uk-breadcrumb>:last-child>a:not([href]), .uk-breadcrumb>:last-child>span {
    color: #222;
}
[data-theme='dark'] .uk-breadcrumb>:last-child>a:not([href]), 
[data-theme='dark'] .uk-breadcrumb>:last-child>span {
    color: #fff;
}

[data-theme='dark'] .uk-h1, [data-theme='dark'] .uk-h2, [data-theme='dark'] .uk-h3, [data-theme='dark'] .uk-h4, [data-theme='dark'] .uk-h5, [data-theme='dark'] .uk-h6, [data-theme='dark'] .uk-heading-2xlarge, [data-theme='dark'] .uk-heading-3xlarge, [data-theme='dark'] .uk-heading-large, [data-theme='dark'] .uk-heading-medium, [data-theme='dark'] .uk-heading-small, [data-theme='dark'] .uk-heading-xlarge, [data-theme='dark'] h1, [data-theme='dark'] h2, [data-theme='dark'] h3, [data-theme='dark'] h4, [data-theme='dark'] h5, [data-theme='dark'] h6 {
    color: #ccc;
}

[data-theme='dark'] .uk-button-default {
    background-color: transparent;
    color: #fff;
    border: 1px solid #e5e5e5;
}

[data-theme='dark'] .uk-accordion-title {
    color: #32d296;
}
uk-link, a {
    color: #129666;
}

[data-theme='dark'] .uk-form-label {
    color: #ccc;
}


/* 5. 既存のハイライト行（令和・平成）の優先順位を確保 */
[data-theme='dark'] .highlight-rewa { background-color: #3d1a1a !important; }
[data-theme='dark'] .highlight-heisei { background-color: #1a263d !important; }


.post-upload-na .uk-navbar-nav > li > a.uk-button-secondary,
.post-upload-na .uk-navbar-nav > li > a.uk-button-primary
 {
    color: #fff;
}

.video-container {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 の比率を維持 */
    height: 0;
    overflow: hidden;
    max-width: 100%;
}

.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}