/* Common Components */
.badge-glass {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.2rem 0.6rem;
    border-radius: 0.5rem;
    font-size: 0.7rem;
    font-weight: 800;
    line-height: 1.2;
    white-space: nowrap;
    letter-spacing: 0.02em;
    /* 閭梧勹繧偵＆繧峨↓逋ｽ縺上＠縲。order繧呈ｿ・￥縲√＆繧峨↓蠖ｱ繧剃ｻ倥￠繧九％縺ｨ縺ｧ繧ｫ繝ｼ繝芽レ譎ｯ縺ｨ縺ｮ蜷悟喧繧帝亟縺・*/
    background: color-mix(in srgb, var(--badge-color) 8%, white);
    color: var(--badge-color);
    border: 1px solid color-mix(in srgb, var(--badge-color) 50%, white);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: all 0.2s ease;
}

[data-theme='dark'] .badge-glass {
    /* 繝繝ｼ繧ｯ繝｢繝ｼ繝峨〒縺ｯ隕冶ｪ肴ｧ蜷台ｸ翫・縺溘ａ縲∵枚蟄苓牡繧偵ｈ繧頑・繧九￥縲∬レ譎ｯ繧貞ｰ代＠豼・￥隱ｿ謨ｴ */
    color: color-mix(in srgb, var(--badge-color), white 45%);
    background: color-mix(in srgb, var(--badge-color), transparent 82%);
}

/* 繧｢繧ｯ繝・ぅ繝悶↑繧ｻ繧ｰ繝｡繝ｳ繝亥・縺ｮ繝舌ャ繧ｸ・・important 縺ｧ遒ｺ螳溘↓蜿崎ｻ｢縺輔○繧・*/
[data-theme='dark'] .segment-item.active .badge-glass {
    background: var(--primary-active-text);
    color: #FFFFFF;
    border: none;
    opacity: 1;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Inter', sans-serif;
    background: var(--bg-body);
    background-attachment: fixed;
    color: var(--text-main);
    min-height: 100vh;
    overflow-x: hidden;
    width: 100%;
    transition: background 0.3s ease, color 0.3s ease;
}

h1,
h2,
h3,
.font-outfit {
    font-family: 'Outfit', sans-serif;
}

.glass-container {
    background: var(--bg-card);
    backdrop-filter: blur(12px);
    border: 1px solid var(--border);
    border-radius: 1.5rem;
    box-shadow: var(--shadow);
    padding: 2.5rem;
    transition: all 0.3s ease;
}

#task-edit-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    padding: 1.5rem;
}

@media (max-width: 768px) {
    .glass-container {
        padding: 1.25rem;
        border-radius: 1rem;
    }
    #task-edit-modal {
        padding: 0.5rem;
    }
    .checklist-row {
        gap: 0.5rem; /* reduce gap on mobile */
    }
    .checklist-row__input {
        padding: 0.5rem; /* slightly less padding */
    }
}

/* --- Glass Container Variations --- */
.glass-container--compact {
    padding: 1.25rem;
}
@media (max-width: 768px) {
    .glass-container--compact {
        padding: 1rem;
    }
}
.glass-container--flush {
    padding: 0;
    overflow: hidden;
}
.glass-container--hero {
    padding: 4rem 1.5rem;
    text-align: center;
    color: var(--text-muted);
}
@media (max-width: 768px) {
    .glass-container--hero {
        padding: 3rem 1rem;
    }
}

/* --- Functional Components --- */
.task-edit-grid-main {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.task-edit-grid-3col {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1rem;
}

.task-edit-grid-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

/* --- Kanban Card (Task Card) --- */
.kanban-card {
    text-decoration: none;
    color: inherit;
    padding: 1.5rem;
    transition: all 0.3s ease;
    cursor: pointer;
    position: relative;
    border-radius: 1.25rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 200px;
}
.kanban-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    border-color: color-mix(in srgb, var(--primary), transparent 70%);
}
@media (max-width: 768px) {
    .kanban-card {
        padding: 1.25rem;
        border-radius: 1rem;
        min-height: 180px;
    }
}

/* --- Segment Control --- */
.segment-control {
    display: flex;
    gap: 0.25rem;
    background: var(--bg-surface);
    padding: 0.25rem;
    border-radius: 12px;
    border: 1px solid var(--border);
}

.segment-control--full .segment-item {
    flex: 1;
}

.segment-item {
    flex: 0 0 auto;
    text-align: center;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-muted);
    transition: all 0.2s ease;
    cursor: pointer;
    border: none;
    background: transparent;
    white-space: nowrap;
}

.segment-item:hover {
    background: rgba(0, 0, 0, 0.05);
    color: var(--text-main);
}
[data-theme='dark'] .segment-item:hover {
    background: rgba(255, 255, 255, 0.05);
}

.segment-item.active {
    background: var(--primary);
    color: var(--primary-active-text);
    box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.3);
}

.segment-item.active:hover {
    background: var(--primary);
    color: white;
}

[data-theme='dark'] .segment-item.active:hover {
    color: var(--primary-active-text);
}

/* --- Task Board Layout --- */
.task-board-stack { 
    display: flex; 
    flex-direction: column; 
    gap: 1.5rem; 
    width: 100%;
}
@media (max-width: 768px) {
    .task-board-stack { gap: 1rem; }
}

input,
select,
textarea {
    background-color: var(--input-bg);
    border: 1px solid var(--border);
    border-radius: 0.75rem;
    color: var(--text-main);
    padding: 0.875rem 1.25rem; /* 蠖薙◆繧雁愛螳壼ｼｷ蛹悶・縺溘ａ蟆代＠蠎・￡繧・*/
    appearance: none;
    transition: all 0.3s ease;
    font-size: 1rem; /* 繝｢繝舌う繝ｫ縺ｧ縺ｮ繧ｺ繝ｼ繝髦ｲ豁｢縺ｮ縺溘ａ 16px 莉･荳翫ｒ謗ｨ螂ｨ */
    width: 100%;
}

@media (max-width: 768px) {
    input, select, textarea {
        padding: 0.75rem 1rem;
        font-size: 16px; /* 繧ｺ繝ｼ繝髦ｲ豁｢ */
    }
    
    /* 繝｢繝ｼ繝繝ｫ蜀・・ 2蛻励げ繝ｪ繝・ラ繧偵Δ繝舌う繝ｫ縺ｧ縺ｯ 1蛻励↓縺吶ｋ */
    .task-edit-grid-main,
    .task-edit-grid-3col,
    .task-edit-grid-2col {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }
}

select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1.2em;
    padding-right: 2.5rem;
}

option {
    background: var(--bg-sidebar);
    color: var(--text-main);
}

input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.2);
}

/* --- Checklist Utilities --- */
.checklist-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}
.checklist-row:last-child {
    margin-bottom: 0;
}
.checklist-row__checkbox {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    appearance: auto;
}
.checklist-row__input {
    flex: 1;
    min-width: 0; /* Ensures it can shrink below its default intrinsic width */
    padding: 0.6rem;
    border-radius: 0.5rem;
    border: 1px solid var(--border);
    background: var(--bg-surface);
    color: var(--text-main);
    font-size: 0.95rem;
}
.checklist-row__delete {
    background: none;
    border: none;
    color: var(--status-danger);
    cursor: pointer;
    font-size: 1.25rem;
    flex-shrink: 0;
    padding: 0.25rem 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* --- Form Utilities --- */
.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}
.input-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-weight: 600;
}
.search-box {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--border);
    border-radius: 0.5rem;
    padding: 0.5rem 1rem;
    color: white;
    font-size: 0.9rem;
    width: 100%;
    max-width: 300px;
    transition: all 0.3s ease;
}
.search-box:focus {
    outline: none;
    border-color: var(--primary);
    background: rgba(255, 255, 255, 0.1);
}

/* --- Data Table --- */
.data-table-container {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 1rem;
    background: var(--bg-card);
    padding: 0;
}
.data-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.data-table thead th {
    background: rgba(0, 0, 0, 0.15);
    padding: 1.25rem 1rem;
    text-align: left;
    font-size: 0.8rem;
    text-transform: uppercase;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
}
.data-table tbody td {
    padding: 1.25rem 1rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.9rem;
}
.data-table tbody tr:hover td {
    background: rgba(255, 255, 255, 0.02);
}

/* Header Layout */
.project-header-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 2.5rem;
    gap: 2rem;
}

.project-title {
    font-size: 2.25rem;
    margin: 0;
    line-height: 1.1;
}

.project-title-section { flex: 1; min-width: 300px; }
.project-overall-progress { width: 100%; max-width: 350px; }

@media (max-width: 1024px) {
    .project-header-container { flex-direction: column; align-items: stretch; gap: 1.5rem; }
    .project-overall-progress { max-width: 100%; }
    .project-title { font-size: 1.8rem; }
}

/* =============================================================
   Button Design System
   - .btn-base : 蜈ｱ騾壼渕逶､・亥・繝懊ち繝ｳ縺ｫ驕ｩ逕ｨ・・   - 繧ｵ繧､繧ｺ   : .btn-sm / .btn-md / .btn-lg・域・遉ｺ逧・↓邨・∩蜷医ｏ縺帙ｋ・・   - 蠖ｩ濶ｲ     : .btn-primary / .btn-secondary / .btn-action-* ・医し繧､繧ｺ縺ｨ縺ｯ迢ｬ遶具ｼ・   ============================================================= */

/* --- 蜈ｱ騾壹・繝ｼ繧ｹ --- */
.btn-base,
.btn-primary,
.btn-secondary,
.btn-action-warning,
.btn-action-danger,
.btn-action-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 0.75rem;
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    /* 繝・ヵ繧ｩ繝ｫ繝医し繧､繧ｺ縺ｯ .btn-md 縺ｨ蜷檎ｭ会ｼ井ｸ頑嶌縺榊庄閭ｽ・・*/
    padding: 0.625rem 1.25rem;
    min-height: 2.5rem;
    border: 1px solid transparent;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

/* --- 繧ｵ繧､繧ｺ繝舌Μ繧｢繝ｳ繝・--- */
/* .btn-sm : 繧ｿ繧ｹ繧ｯ繧ｫ繝ｼ繝峨・繝・・繝悶Ν蜀・↑縺ｩ縺ｮ繧ｳ繝ｳ繝代け繝育畑騾・*/
.btn-sm {
    padding: 0.35rem 0.75rem;
    min-height: 2rem;
    font-size: 0.775rem;
    border-radius: 0.5rem;
    gap: 0.3rem;
}

/* .btn-md : 讓呎ｺ厄ｼ医ョ繝輔か繝ｫ繝医→蜷檎ｭ峨・縺溘ａ逵∫払蜿ｯ縺縺梧・遉ｺ逕ｨ縺ｨ縺励※螳夂ｾｩ・・*/
.btn-md {
    padding: 0.625rem 1.25rem;
    min-height: 2.5rem;
    font-size: 0.875rem;
}

/* .btn-lg : 繝倥ャ繝繝ｼ繧・㍾隕√い繧ｯ繧ｷ繝ｧ繝ｳ逕ｨ・域立譚･縺ｮ 3rem 繧ｵ繧､繧ｺ・・*/
.btn-lg {
    padding: 0.75rem 1.75rem;
    min-height: 3rem;
    font-size: 0.95rem;
    border-radius: 0.85rem;
    gap: 0.6rem;
}

/* --- 蠖ｩ濶ｲ繝舌Μ繧｢繝ｳ繝・--- */
.btn-primary {
    background: linear-gradient(135deg, var(--primary), var(--primary-light));
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.2);
}

[data-theme='dark'] .btn-primary {
    color: var(--primary-active-text);
}

.btn-secondary,
.btn-action-outline {
    background: var(--glass);
    color: var(--text-muted);
    border: 1px solid var(--border);
    backdrop-filter: blur(12px);
}

.btn-action-warning {
    --btn-color: var(--status-warning);
    background: color-mix(in srgb, var(--btn-color), transparent 85%);
    color: var(--btn-color);
    border: 1px solid color-mix(in srgb, var(--btn-color), transparent 70%);
    backdrop-filter: blur(12px);
}

.btn-action-danger {
    --btn-color: var(--status-danger);
    background: color-mix(in srgb, var(--btn-color), transparent 85%);
    color: var(--btn-color);
    border: 1px solid color-mix(in srgb, var(--btn-color), transparent 70%);
    backdrop-filter: blur(12px);
}

/* --- 繝帙ヰ繝ｼ蜉ｹ譫・--- */
.btn-primary:hover {
    transform: translateY(-2px);
    opacity: 0.92;
    box-shadow: 0 12px 20px -5px rgba(var(--primary-rgb), 0.4);
}

.btn-secondary:hover,
.btn-action-outline:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--primary-light);
    color: var(--text-main);
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.btn-action-warning:hover {
    background: color-mix(in srgb, var(--btn-color), transparent 75%);
    transform: translateY(-2px);
    box-shadow: 0 8px 15px -3px rgba(217, 119, 6, 0.2);
}

.btn-action-danger:hover {
    background: color-mix(in srgb, var(--btn-color), transparent 75%);
    transform: translateY(-2px);
    box-shadow: 0 8px 15px -3px rgba(239, 68, 68, 0.2);
}



.alert-error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #F87171;
    padding: 1rem;
    border-radius: 0.75rem;
    margin-bottom: 1rem;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade {
    animation: fadeIn 0.5s ease forwards;
}

/* PC迚医し繧､繝峨ヰ繝ｼ蝓ｺ譛ｬ繧ｹ繧ｿ繧､繝ｫ */
.sidebar-desktop {
    width: 280px;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    background: var(--bg-sidebar);
    border-right: 1px solid var(--border);
    padding: 2.5rem 1.25rem;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    transition: all 0.3s ease;
}

.sidebar-desktop nav {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex-grow: 1;
}

.nav-item {
    display: flex;
    align-items: center;
    padding: 0.75rem 1.25rem;
    border-radius: 0.85rem;
    color: var(--text-muted);
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
    font-size: 0.85rem;
    border: 1px solid transparent;
}

/* 繝・く繧ｹ繝医Λ繝吶Ν莉･螟悶・縺吶∋縺ｦ縺ｮ span 繧偵い繧､繧ｳ繝ｳ縺ｨ縺励※謇ｱ縺・*/
.nav-item > span:not(.nav-label) {
    font-size: 1.2rem;
    margin-right: 0.85rem;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease;
}

.nav-label {
    font-size: 0.85rem;
    white-space: nowrap;
}

.nav-item:hover {
    background: var(--glass);
    color: var(--primary-light);
    transform: translateX(4px);
}

.nav-item.active {
    background: rgba(79, 70, 229, 0.1);
    color: var(--primary);
    border: 1px solid rgba(79, 70, 229, 0.2);
    font-weight: 700;
}

[data-theme='dark'] .nav-item.active {
    background: rgba(79, 70, 229, 0.15);
    color: var(--primary-light);
    border: 1px solid rgba(79, 70, 229, 0.3);
}

.main-container {
    margin-left: 0;
    padding: 3rem;
    min-height: 100vh;
    width: 100%;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* 繝｢繝舌う繝ｫ繝ｻ繧ｿ繝悶Ξ繝・ヨ縺ｧ縺ｮ菴咏區隱ｿ謨ｴ */
@media (max-width: 1024px) {
    .main-container { padding: 1rem; }
}
@media (max-width: 768px) {
    .main-container { padding: 0.75rem; }
}

/* 繝ｭ繧ｰ繧､繝ｳ荳ｭ縺九▽PC迚医・蝣ｴ蜷医・縺ｿ繝槭・繧ｸ繝ｳ繧剃ｻ倅ｸ趣ｼ医し繧､繝峨ヰ繝ｼ縺碁幕縺・※縺・ｋ譎る剞螳夲ｼ・*/
@media (min-width: 769px) {
    html:not(.sidebar-collapsed) body:not(.login-page) .main-container {
        margin-left: var(--sidebar-width, 280px);
        width: calc(100% - var(--sidebar-width, 280px));
    }
    
    html.sidebar-collapsed .main-container {
        margin-left: 80px;
        width: calc(100% - 80px);
    }

    /* Sidebar Collapsed Styles (PC only) */
    .sidebar-collapsed .sidebar-desktop { width: 80px; padding: 1.5rem 0.75rem; }
}

/* 縺ｴ繧・ｓ迴ｾ雎｡蟇ｾ遲・ 豸亥悉縺ｧ縺ｯ縺ｪ縺城ｫ伜ｺｦ縺ｪ髫阡ｽ */
.sidebar-collapsed .sidebar-logo { 
    opacity: 0;
    height: 0;
    margin-bottom: 0;
    padding: 0;
    pointer-events: none;
    overflow: hidden;
}

.sidebar-collapsed .nav-label { display: none; }
.sidebar-collapsed .nav-item { justify-content: center; padding: 0.85rem; margin-bottom: 0.2rem; }
.sidebar-collapsed .nav-item span { margin-right: 0; font-size: 1.25rem; }
.sidebar-collapsed .toggle-btn span { transform: rotate(180deg); }

.toggle-btn {
    position: absolute;
    right: -12px;
    top: 45px;
    width: 24px;
    height: 24px;
    background: var(--primary);
    border: none;
    border-radius: 50%;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 1001;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.toggle-btn:hover { background: var(--primary-light); transform: scale(1.1); }

/* 蜃ｺ縺怜・縺醍畑繧ｯ繝ｩ繧ｹ (PC/繝｢繝舌う繝ｫ) */
.mobile-only {
    display: none;
}

.desktop-only {
    display: block;
}

/* 蜈ｱ騾壹Ξ繧､繧｢繧ｦ繝医け繝ｩ繧ｹ */
.responsive-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
}

.kanban-board {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: start;
}

@media (max-width: 1024px) {
    .responsive-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .mobile-only {
        display: block;
    }

    .desktop-only {
        display: none;
    }

    .toggle-btn {
        display: none;
    }

    /* 繝｢繝舌う繝ｫ逕ｨ繝懊ヨ繝繝翫ン繧ｲ繝ｼ繧ｷ繝ｧ繝ｳ */
    .nav-mobile {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: calc(70px + env(safe-area-inset-bottom, 0px));
        padding-bottom: env(safe-area-inset-bottom, 0px);
        background: var(--bg-sidebar);
        border-top: 1px solid var(--border);
        display: flex;
        z-index: 1000;
        backdrop-filter: blur(12px);
    }

    .nav-mobile nav {
        display: flex;
        width: 100%;
        justify-content: space-around;
        align-items: center;
    }

    /* 繝懊ヨ繝繝翫ン繧ｲ繝ｼ繧ｷ繝ｧ繝ｳ蟆ら畑縺ｮ BEM 繧ｯ繝ｩ繧ｹ */
    .bottom-nav__item {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 0.5rem 0.25rem;
        gap: 2px;
        color: var(--text-muted);
        text-decoration: none;
        font-size: 0.65rem;
        font-weight: 500;
        height: 100%;
        border-radius: 0;
        border: none;
        background: transparent;
        text-align: center;
        transition: color 0.2s;
    }

    .bottom-nav__item div {
        width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .bottom-nav__item span {
        font-size: 1.25rem;
        margin: 0; /* 繝槭・繧ｸ繝ｳ繧貞ｮ悟・縺ｫ繝ｪ繧ｻ繝・ヨ */
        transition: none; /* 繝・せ繧ｯ繝医ャ繝礼畑縺ｮ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ蟷ｲ貂峨ｒ謗帝勁 */
    }

    .bottom-nav__item--active {
        color: var(--primary);
        background: transparent;
    }

    .main-container {
        margin-left: 0;
        width: 100%;
        padding: 1.25rem;
        padding-bottom: calc(90px + env(safe-area-inset-bottom, 0px)); /* ナビゲーションの高さ + 余白 + セーフエリア */
    }
}

/* 騾ｲ謐励ヰ繝ｼ */
.progress-bar-bg {
    background: var(--bg-surface);
    overflow: hidden;
    border: 1px solid var(--border);
}

.progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary), var(--primary-light));
    transition: width 0.6s ease;
}

/* 繧ｿ繝悶Γ繝九Η繝ｼ */
.project-tabs {
    margin-top: 2rem;
    display: flex;
    gap: 0.5rem;
    border-bottom: 2px solid var(--border);
    flex-wrap: wrap;
}

.tab-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    padding: 1rem 1.5rem;
    font-weight: 600;
    cursor: pointer;
    position: relative;
    transition: all 0.2s ease;
    white-space: nowrap;
}

@media (max-width: 768px) {
    .tab-btn {
        padding: 0.75rem 1rem;
        font-size: 0.85rem;
    }
}

.tab-btn:hover {
    color: var(--text-main);
}

.tab-btn.active {
    color: var(--primary);
}

.tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--primary);
    border-radius: 3px 3px 0 0;
}

.tab-content {
    display: none;
    animation: fadeIn 0.4s ease;
}

.tab-content.active {
    display: block;
}

/* 繧ｹ繝・・繧ｿ繧ｹ繝舌ャ繧ｸ */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-pending_dept {
    background: rgba(245, 158, 11, 0.1);
    color: var(--status-warning);
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.status-pending_hq {
    background: rgba(79, 70, 229, 0.1);
    color: var(--primary);
    border: 1px solid rgba(79, 70, 229, 0.2);
}

.status-approved {
    background: rgba(16, 185, 129, 0.1);
    color: var(--status-success);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.status-rejected {
    background: rgba(239, 68, 68, 0.1);
    color: var(--status-danger);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

.status-draft {
    background: rgba(148, 163, 184, 0.1);
    color: #94A3B8;
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.status-in_progress {
    background: rgba(59, 130, 246, 0.1);
    color: #3B82F6;
    border: 1px solid rgba(59, 130, 246, 0.2);
}

.status-completed {
    background: rgba(16, 185, 129, 0.1);
    color: var(--status-success);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.status-suspended {
    background: rgba(245, 158, 11, 0.1);
    color: #F59E0B;
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.status-discarded {
    background: rgba(71, 85, 105, 0.1);
    color: #94A3B8;
    border: 1px solid rgba(71, 85, 105, 0.2);
    opacity: 0.7;
}

/* 譯井ｻｶ繧｢繧ｳ繝ｼ繝・ぅ繧ｪ繝ｳ蜈ｱ騾壹せ繧ｿ繧､繝ｫ (蝓ｺ譛ｬ螳夂ｾｩ縺ｮ縺ｿ) */
.project-section { margin-bottom: 1.5rem; }
.project-header::-webkit-details-marker { display: none; }

.task-list-container { 
    padding: 1.5rem; 
    background: rgba(0, 0, 0, 0.1); 
    border-top: 1px solid var(--border);
}

details .chevron { transition: transform 0.3s ease; font-size: 0.8rem; color: var(--text-muted); }
details[open] .chevron { transform: rotate(180deg); }

/* =============================================================
   Project Timeline Component
   ============================================================= */

/* --- 繧ｿ繧､繝繝ｩ繧､繝ｳ繧ｳ繝ｳ繝・リ --- */
.project-timeline {
    background: var(--bg-card);
    backdrop-filter: blur(12px);
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    padding: 1.5rem;
    margin-bottom: 2rem;
}

@media (max-width: 768px) {
    .project-timeline {
        padding: 1rem;
        border-radius: 1rem;
        margin-bottom: 1.5rem;
    }
}

.project-timeline__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.project-timeline__title {
    font-family: 'Outfit', sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.project-timeline__dates {
    font-size: 0.75rem;
    color: var(--text-muted);
    display: flex;
    gap: 0.5rem;
}

/* --- 繧ｿ繧ｹ繧ｯ繧ｨ繝ｪ繧｢蜈ｨ菴薙・閭梧勹繧ｳ繝ｳ繝・リ・域｡井ｻｶ蜈ｨ菴捺悄髢薙ｒ證礼､ｺ縺吶ｋ髱｢・・--- */
.project-timeline__area {
    position: relative;
    background: var(--bg-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--border);
    padding: 0.75rem;
    /* 笆ｼ/笆ｲ繝上Φ繝峨Ν縺ｮ縺ｯ縺ｿ蜃ｺ縺励ｒ險ｱ螳ｹ縺吶ｋ */
    overflow: visible;
}

/* 縲御ｻ頑律縲咲ｸｦ繝ｩ繧､繝ｳ・壹ち繧ｹ繧ｯ繝舌・縺ｮ閭悟ｾ後ｒ雋ｫ騾壹・繧ｯ繝ｪ繝・け縺ｯ騾城℃縺輔○繧・*/
.project-timeline__today-line {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2px;
    /* 2px縺ｮ荳ｭ螟ｮ繧剃ｻ頑律縺ｮ菴咲ｽｮ縺ｫ蜷医ｏ縺帙ｋ */
    left: calc(var(--today-pos, 50%) - 1px);
    background: var(--status-danger);
    border-radius: 1px;
    /* 繧ｿ繧ｹ繧ｯ繝舌・縺ｮ繧ｯ繝ｪ繝・け繧剃ｸ蛻・が鬲斐＠縺ｪ縺・*/
    pointer-events: none;
    z-index: 1;
    box-shadow: 0 0 6px rgba(239, 68, 68, 0.35);
}

/* 縲御ｻ頑律縲阪ワ繝ｳ繝峨Ν・遺名/笆ｲ・牙・騾夲ｼ壹％縺薙□縺代け繝ｪ繝・け蜿ｯ閭ｽ */
.project-timeline__today-handle {
    position: absolute;
    left: var(--today-pos, 50%);
    transform: translateX(-50%);
    background: none;
    border: none;
    padding: 2px 4px;
    cursor: pointer;
    color: var(--status-danger);
    font-size: 0.55rem;
    line-height: 1;
    /* 繧ｿ繧ｹ繧ｯ繝舌・・・-index:2・峨ｈ繧雁燕髱｢縺ｫ蜃ｺ縺・*/
    z-index: 20;
    pointer-events: auto;
    transition: opacity 0.15s ease, transform 0.15s ease;
}
.project-timeline__today-handle:hover {
    opacity: 0.75;
    transform: translateX(-50%) scale(1.3);
}
.project-timeline__today-handle--top {
    top: -14px;
}
.project-timeline__today-handle--bottom {
    bottom: -14px;
}

/* 縲御ｻ頑律縲肴律莉倥ヤ繝ｼ繝ｫ繝√ャ繝暦ｼ医ワ繝ｳ繝峨Ν繧ｯ繝ｪ繝・け縺ｧ is-visible 繧ｯ繝ｩ繧ｹ繧剃ｻ倅ｸ趣ｼ・*/
.project-timeline__today-tooltip {
    position: absolute;
    left: var(--today-pos, 50%);
    top: 50%;
    transform: translate(-50%, -50%);
    background: var(--bg-sidebar);
    border: 1px solid var(--status-danger);
    border-radius: 0.5rem;
    padding: 0.3rem 0.7rem;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--status-danger);
    white-space: nowrap;
    /* 繝ｩ繧､繝ｳ蜷梧ｧ倥け繝ｪ繝・け縺ｯ騾城℃・医ヤ繝ｼ繝ｫ繝√ャ繝苓・菴薙・謫堺ｽ懊＠縺ｪ縺・ｼ・*/
    pointer-events: none;
    opacity: 0;
    z-index: 30;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.15);
    transition: opacity 0.2s ease;
}
.project-timeline__today-tooltip.is-visible {
    opacity: 1;
}

/* --- 繧ｿ繧ｹ繧ｯ繝ｬ繧､繝､繝ｼ・亥推繧ｿ繧ｹ繧ｯ縺ｮ譛滄俣繝舌・蛻暦ｼ・--- */
.project-timeline__tasks {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 6px;
    /* __area 縺ｮ padding 蜀・↓蜿弱∪繧九◆繧・padding-top 荳崎ｦ・*/
}

.project-timeline__row {
    position: relative;
    height: 24px;
    display: flex;
    align-items: center;
}

/* 繧ｿ繧ｹ繧ｯ蜈ｨ菴薙ｒ蛹・・繧ｳ繝ｳ繝・リ・医Λ繝吶Ν陦ｨ遉ｺ縺ｨ繝帙ヰ繝ｼ蛻､螳壹・蝓ｺ轤ｹ・・*/
.project-timeline__task-wrapper {
    position: absolute;
    left: var(--total-start, 0%);
    width: var(--total-width, 10%);
    height: 100%;
    z-index: 2;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: transform 0.2s ease;
    will-change: transform;
    backface-visibility: hidden;
    transform-origin: center center;
}

.project-timeline__task-wrapper:hover {
    transform: scaleY(1.1);
    z-index: 20;
}

/* wrapper繝帙ヰ繝ｼ譎ゅ∽ｸｭ縺ｮ繝舌・繧剃ｸ諡ｬ縺励※譏弱ｋ縺上☆繧・*/
.project-timeline__task-wrapper:hover .project-timeline__bar {
    filter: brightness(1.2);
}

/* 繧ｯ繝ｪ繝・け縺ｧ繧｢繧ｯ繝・ぅ繝也憾諷九↓縺ｪ縺｣縺溘→縺・*/
.project-timeline__task-wrapper.is-active {
    z-index: 25;
}
.project-timeline__task-wrapper.is-active .project-timeline__bar {
    filter: brightness(1.25);
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

/* 繧ｿ繧ｹ繧ｯ譛滄俣繝舌・譛ｬ菴難ｼ・rapper 蜀・〒縺ｮ逶ｸ蟇ｾ驟咲ｽｮ・・*/
.project-timeline__bar {
    position: absolute;
    left: var(--bar-start, 0%);
    width: calc(var(--bar-width, 10%) + 1px); /* 繧ｵ繝悶ヴ繧ｯ繧ｻ繝ｫ縺ｮ髫咎俣繧貞｡槭＄ */
    height: 100%;
    background: var(--bar-color, var(--primary));
    opacity: 1;
    min-width: 4px;
    pointer-events: none; /* 繧ｯ繝ｪ繝・け蛻､螳壹・ wrapper 縺ｫ莉ｻ縺帙ｋ */
    transition: filter 0.2s ease, box-shadow 0.2s ease;
    will-change: filter, box-shadow;
    backface-visibility: hidden; /* 謠冗判繝悶Ξ縺ｮ髦ｲ豁｢ */
}

/* 繝ｩ繝吶Ν・亥・菴灘ｹ・↓蟇ｾ縺励※陦ｨ遉ｺ・・*/
.project-timeline__label {
    position: absolute;
    left: 0;
    width: 100%;
    text-align: center;
    font-size: 0.65rem;
    font-weight: 800; /* 螟ｪ縺輔ｒ蠑ｷ隱ｿ */
    color: white;
    white-space: nowrap;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.4rem;
    z-index: 5; /* 繝舌・繧医ｊ蜑埼擇 */
    /* くっきり感を出すため、ぼかしを最小限にした鋭いシャドウに変更 */
    text-shadow: 
        1px 1px 0px rgba(0, 0, 0, 0.8),
        -1px -1px 0px rgba(0, 0, 0, 0.8),
        1px -1px 0px rgba(0, 0, 0, 0.8),
        -1px 1px 0px rgba(0, 0, 0, 0.8),
        0 2px 4px rgba(0, 0, 0, 0.5);
}

.project-timeline__label-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

[data-theme='dark'] .project-timeline__label {
    color: var(--primary-active-text);
    /* ダークモードでは白いシャドウでくっきり感を出す */
    text-shadow:
        1px 1px 0px rgba(255, 255, 255, 0.4),
        -1px -1px 0px rgba(255, 255, 255, 0.4),
        1px -1px 0px rgba(255, 255, 255, 0.4),
        -1px 1px 0px rgba(255, 255, 255, 0.4);
}

@media (max-width: 768px) {
    .project-timeline__label-text {
        display: none;
    }
}

/* 繝・・繝ｫ繝√ャ繝・*/
.project-timeline__tooltip {
    position: absolute;
    bottom: 130%;
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-sidebar);
    border: 1px solid var(--border);
    border-radius: 0.5rem;
    padding: 0.35rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-main);
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    z-index: 100;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    transition: opacity 0.15s ease;
}

.project-timeline__tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--border);
}

/* 繝ｩ繝・ヱ繝ｼ縺ｮ繝帙ヰ繝ｼ縺ｧ繝・・繝ｫ繝√ャ繝励ｒ陦ｨ遉ｺ */
.project-timeline__task-wrapper:hover + .project-timeline__tooltip,
.project-timeline__tooltip.is-visible {
    opacity: 1;
}

/* 雜・℃繝ｻ驕・ｻｶ縺ｮ諡｡蠑ｵ繝舌・ */
.project-timeline__bar--hatched {
    background-image: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 4px,
        var(--timeline-hatch) 4px,
        var(--timeline-hatch) 8px
    );
    background-color: var(--bar-color, var(--primary));
}

/* 譛滄俣譛ｪ險ｭ螳壽凾縺ｮ繝輔か繝ｼ繝ｫ繝舌ャ繧ｯ陦ｨ遉ｺ */
.project-timeline__no-period {
    text-align: center;
    padding: 1.5rem;
    color: var(--text-muted);
    font-size: 0.8rem;
}

/* =============================================================
   Pagination Styles (Bootstrap 5 Overrides for Vanilla CSS)
   ============================================================= */
.pagination {
    display: flex;
    padding-left: 0;
    list-style: none;
    justify-content: center;
    gap: 0.4rem;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
}

.page-item .page-link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.85rem;
    font-family: 'Outfit', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-muted);
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: 0.6rem;
    text-decoration: none;
    transition: all 0.2s ease;
    min-width: 2.5rem;
}

.page-item.active .page-link {
    z-index: 3;
    color: white;
    background: linear-gradient(135deg, var(--primary), var(--primary-light));
    border-color: transparent;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3); /* primary-rgb equivalent */
}

.page-item.disabled .page-link {
    color: color-mix(in srgb, var(--text-muted), transparent 50%);
    pointer-events: none;
    background: rgba(0,0,0,0.03);
}

.page-item .page-link:hover {
    color: var(--primary-light);
    background: var(--glass);
    border-color: var(--primary-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

/* --- Functional Icons (Text Color Sync) --- */
.icon-inline {
    display: inline-block;
    width: 1.1em;
    height: 1.1em;
    background-color: currentColor;
    vertical-align: -0.15em;
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
}


/* 隕冶ｪ肴ｧ繧呈･ｵ髯舌∪縺ｧ鬮倥ａ縺溯ｭｦ蜻翫ヰ繝・ず・医ワ繧､繧ｳ繝ｳ繝医Λ繧ｹ繝医・繝阪が繝ｳ蜉ｹ譫懶ｼ・*/
/* 隴ｦ蜻翫ヰ繝・ず・壹・繝ｼ繧ｹ・磯ｻ・牡縺・ｨ呵ｭ倥い繧､繧ｳ繝ｳ・・*/
.icon-warning-vivid {
    display: inline-block;
    width: 1.4em;
    height: 1.4em;
    vertical-align: middle;
    margin-left: 0.4rem;
    background-color: transparent; /* 譁・ｭ苓牡縺ｧ縺ｮ蝪励ｊ縺､縺ｶ縺励ｒ蠑ｷ蛻ｶ隗｣髯､ */

    /* 鮟・牡・矩ｻ偵・繧ｫ繝ｩ繝ｼSVG縺ｮ縺ｿ繧定｡ｨ遉ｺ */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z' fill='%23FFC107' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cline x1='12' y1='9' x2='12' y2='13' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

/* 菫ｮ豁｣蠕鯉ｼ壹ヰ繝ｼ縺ｮ繝ｩ繝吶Ν・域枚蟄暦ｼ蛾Κ蛻・↓縺・ｋ譎ゅ□縺題｣・｣ｾ繧帝←逕ｨ */
/* 修正後：ぼかしの強い Glow をやめ、くっきりしたアウトラインに変更 */
.project-timeline__label .icon-warning-vivid {
    filter: 
        drop-shadow(1px 0 0 #fff) 
        drop-shadow(-1px 0 0 #fff) 
        drop-shadow(0 1px 0 #fff) 
        drop-shadow(0 -1px 0 #fff)
        drop-shadow(0 1px 2px rgba(0,0,0,0.5));
}

.icon-user {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E");
}

.icon-lock {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'%3E%3C/path%3E%3C/svg%3E");
}

.icon-alert-triangle {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'%3E%3C/path%3E%3Cline x1='12' y1='9' x2='12' y2='13'%3E%3C/line%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'%3E%3C/path%3E%3Cline x1='12' y1='9' x2='12' y2='13'%3E%3C/line%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
}

.icon-play {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='5 3 19 12 5 21 5 3'%3E%3C/polygon%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='5 3 19 12 5 21 5 3'%3E%3C/polygon%3E%3C/svg%3E");
}

.icon-calendar {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
}

.icon-folder {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 19a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h5l2 3h9a2 2 0 0 1 2 2z'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 19a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h5l2 3h9a2 2 0 0 1 2 2z'%3E%3C/path%3E%3C/svg%3E");
}

.icon-dashboard {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'%3E%3C/rect%3E%3Crect x='14' y='3' width='7' height='7'%3E%3C/rect%3E%3Crect x='14' y='14' width='7' height='7'%3E%3C/rect%3E%3Crect x='3' y='14' width='7' height='7'%3E%3C/rect%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'%3E%3C/rect%3E%3Crect x='14' y='3' width='7' height='7'%3E%3C/rect%3E%3Crect x='14' y='14' width='7' height='7'%3E%3C/rect%3E%3Crect x='3' y='14' width='7' height='7'%3E%3C/rect%3E%3C/svg%3E");
}

.icon-bell {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 8A6 6 0 0 0 6 8c0 7-3 9-3 9h18s-3-2-3-9'%3E%3C/path%3E%3Cpath d='M13.73 21a2 2 0 0 1-3.46 0'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 8A6 6 0 0 0 6 8c0 7-3 9-3 9h18s-3-2-3-9'%3E%3C/path%3E%3Cpath d='M13.73 21a2 2 0 0 1-3.46 0'%3E%3C/path%3E%3C/svg%3E");
}

.icon-clipboard {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'%3E%3C/path%3E%3Crect x='8' y='2' width='8' height='4' rx='1' ry='1'%3E%3C/rect%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'%3E%3C/path%3E%3Crect x='8' y='2' width='8' height='4' rx='1' ry='1'%3E%3C/rect%3E%3C/svg%3E");
}

.icon-building {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='16' height='20' x='4' y='2' rx='2' ry='2'/%3E%3Cpath d='M9 22v-4h6v4'/%3E%3Cpath d='M8 6h.01'/%3E%3Cpath d='M16 6h.01'/%3E%3Cpath d='M8 10h.01'/%3E%3Cpath d='M16 10h.01'/%3E%3Cpath d='M8 14h.01'/%3E%3Cpath d='M16 14h.01'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='16' height='20' x='4' y='2' rx='2' ry='2'/%3E%3Cpath d='M9 22v-4h6v4'/%3E%3Cpath d='M8 6h.01'/%3E%3Cpath d='M16 6h.01'/%3E%3Cpath d='M8 10h.01'/%3E%3Cpath d='M16 10h.01'/%3E%3Cpath d='M8 14h.01'/%3E%3Cpath d='M16 14h.01'/%3E%3C/svg%3E");
}

.icon-money {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='1' x2='12' y2='23'%3E%3C/line%3E%3Cpath d='M17 5H9.5a3.5 3.5 0 0 0 0 7h5a3.5 3.5 0 0 1 0 7H6'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='1' x2='12' y2='23'%3E%3C/line%3E%3Cpath d='M17 5H9.5a3.5 3.5 0 0 0 0 7h5a3.5 3.5 0 0 1 0 7H6'%3E%3C/path%3E%3C/svg%3E");
}

.icon-check {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
}

.icon-cross {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
}

.icon-warning {
    display: inline-block;
    width: 1.4em;
    height: 1.4em;
    vertical-align: middle;
    background-color: transparent; /* 譁・ｭ苓牡縺ｧ縺ｮ蝪励ｊ縺､縺ｶ縺励ｒ蠑ｷ蛻ｶ隗｣髯､ */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z' fill='%23FFC107' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cline x1='12' y1='9' x2='12' y2='13' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-mask-image: none;
    mask-image: none;
}

.icon-sun {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'%3E%3C/circle%3E%3Cline x1='12' y1='2' x2='12' y2='6'%3E%3C/line%3E%3Cline x1='12' y1='18' x2='12' y2='22'%3E%3C/line%3E%3Cline x1='4.93' y1='4.93' x2='7.76' y2='7.76'%3E%3C/line%3E%3Cline x1='16.24' y1='16.24' x2='19.07' y2='19.07'%3E%3C/line%3E%3Cline x1='2' y1='12' x2='6' y2='12'%3E%3C/line%3E%3Cline x1='18' y1='12' x2='22' y2='12'%3E%3C/line%3E%3Cline x1='4.93' y1='19.07' x2='7.76' y2='16.24'%3E%3C/line%3E%3Cline x1='16.24' y1='7.76' x2='19.07' y2='4.93'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'%3E%3C/circle%3E%3Cline x1='12' y1='2' x2='12' y2='6'%3E%3C/line%3E%3Cline x1='12' y1='18' x2='12' y2='22'%3E%3C/line%3E%3Cline x1='4.93' y1='4.93' x2='7.76' y2='7.76'%3E%3C/line%3E%3Cline x1='16.24' y1='16.24' x2='19.07' y2='19.07'%3E%3C/line%3E%3Cline x1='2' y1='12' x2='6' y2='12'%3E%3C/line%3E%3Cline x1='18' y1='12' x2='22' y2='12'%3E%3C/line%3E%3Cline x1='4.93' y1='19.07' x2='7.76' y2='16.24'%3E%3C/line%3E%3Cline x1='16.24' y1='7.76' x2='19.07' y2='4.93'%3E%3C/line%3E%3C/svg%3E");
}

.icon-moon {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z'%3E%3C/path%3E%3C/svg%3E");
}

.icon-logout {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'%3E%3C/path%3E%3Cpolyline points='16 17 21 12 16 7'%3E%3C/polyline%3E%3Cline x1='21' y1='12' x2='9' y2='12'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'%3E%3C/path%3E%3Cpolyline points='16 17 21 12 16 7'%3E%3C/polyline%3E%3Cline x1='21' y1='12' x2='9' y2='12'%3E%3C/line%3E%3C/svg%3E");
}

.icon-cog {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 15a3 3 0 1 0 0-6 3 3 0 0 0 0 6Z'%3E%3C/path%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1Z'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 15a3 3 0 1 0 0-6 3 3 0 0 0 0 6Z'%3E%3C/path%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1Z'%3E%3C/path%3E%3C/svg%3E");
}

.icon-pin {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='17' x2='12' y2='22'%3E%3C/line%3E%3Cpath d='M5 17h14v-1.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.68V6a3 3 0 1 0-6 0v4.68a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24Z'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='17' x2='12' y2='22'%3E%3C/line%3E%3Cpath d='M5 17h14v-1.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.68V6a3 3 0 1 0-6 0v4.68a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24Z'%3E%3C/path%3E%3C/svg%3E");
}

.icon-edit {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7'%3E%3C/path%3E%3Cpath d='M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7'%3E%3C/path%3E%3Cpath d='M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z'%3E%3C/path%3E%3C/svg%3E");
}

.icon-help {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
}

.icon-search {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
}

.icon-bolt {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'%3E%3C/polygon%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'%3E%3C/polygon%3E%3C/svg%3E");
}

.icon-clock {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
}

.icon-chart {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='20' x2='18' y2='10'%3E%3C/line%3E%3Cline x1='12' y1='20' x2='12' y2='4'%3E%3C/line%3E%3Cline x1='6' y1='20' x2='6' y2='14'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='20' x2='18' y2='10'%3E%3C/line%3E%3Cline x1='12' y1='20' x2='12' y2='4'%3E%3C/line%3E%3Cline x1='6' y1='20' x2='6' y2='14'%3E%3C/line%3E%3C/svg%3E");
}

.icon-login {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h4a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2h-4'%3E%3C/path%3E%3Cpolyline points='10 17 15 12 10 7'%3E%3C/polyline%3E%3Cline x1='15' y1='12' x2='3' y2='12'%3E%3C/line%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h4a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2h-4'%3E%3C/path%3E%3Cpolyline points='10 17 15 12 10 7'%3E%3C/polyline%3E%3Cline x1='15' y1='12' x2='3' y2='12'%3E%3C/line%3E%3C/svg%3E");
}

.icon-file-text {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'%3E%3C/path%3E%3Cpolyline points='14 2 14 8 20 8'%3E%3C/polyline%3E%3Cline x1='16' y1='13' x2='8' y2='13'%3E%3C/line%3E%3Cline x1='16' y1='17' x2='8' y2='17'%3E%3C/line%3E%3Cpolyline points='10 9 9 9 8 9'%3E%3C/polyline%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'%3E%3C/path%3E%3Cpolyline points='14 2 14 8 20 8'%3E%3C/polyline%3E%3Cline x1='16' y1='13' x2='8' y2='13'%3E%3C/line%3E%3Cline x1='16' y1='17' x2='8' y2='17'%3E%3C/line%3E%3Cpolyline points='10 9 9 9 8 9'%3E%3C/polyline%3E%3C/svg%3E");
}

.icon-corner-up-left {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 14 4 9 9 4'%3E%3C/polyline%3E%3Cpath d='M20 20v-7a4 4 0 0 0-4-4H4'%3E%3C/path%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 14 4 9 9 4'%3E%3C/polyline%3E%3Cpath d='M20 20v-7a4 4 0 0 0-4-4H4'%3E%3C/path%3E%3C/svg%3E");
}


