/* ==========================================================================
   UI PARTS CSS for WordPress Cocoon Theme
   Version: 1.0.0
   Prefix: .ui-
   ========================================================================== */


/* ==========================================================================
   1. COLOR TOKENS & CSS VARIABLES
   ========================================================================== */

:root {
  /* Brand (Fixed) */
  --ui-accent:           #344875;
  --ui-accent-sub:       #D9BFA3;

  /* Accent Variants */
  --ui-accent-light:     #2C4170;
  --ui-accent-pale:      #EEF1F7;
  --ui-accent-sub-light: #F5EDE0;
  --ui-accent-sub-dark:  #B89A7A;

  /* Neutral */
  --ui-white:     #FFFFFF;
  --ui-gray-50:   #F8F7F5;
  --ui-gray-100:  #F0EFEC;
  --ui-gray-200:  #E4E2DC;
  --ui-gray-300:  #C9C6BC;
  --ui-gray-500:  #8A877E;
  --ui-gray-700:  #4A4841;
  --ui-gray-900:  #1E1D1A;

  /* Semantic */
  --ui-info:        #2563EB;
  --ui-info-bg:     #EFF6FF;
  --ui-info-border: #BFDBFE;
  --ui-warn:        #D97706;
  --ui-warn-bg:     #FFFBEB;
  --ui-warn-border: #FDE68A;
  --ui-success:     #059669;
  --ui-success-bg:  #ECFDF5;
  --ui-danger:      #DC2626;
  --ui-danger-bg:   #FEF2F2;

  /* EC Buttons */
  --ui-amazon:       #FF9900;
  --ui-amazon-dark:  #E68800;
  --ui-amazon-text:  #111111;
  --ui-rakuten:      #BF0000;
  --ui-rakuten-dark: #9E0000;
  --ui-rakuten-text: #FFFFFF;

  /* Typography */
  --ui-font-xs:  0.75rem;
  --ui-font-sm:  0.875rem;
  --ui-font-base:1rem;
  --ui-font-lg:  1.125rem;
  --ui-font-h:   clamp(1.25rem, 3vw, 1.5rem);

  /* Spacing (8px scale) */
  --ui-sp-1: 8px;
  --ui-sp-2: 16px;
  --ui-sp-3: 24px;
  --ui-sp-4: 32px;
  --ui-sp-5: 40px;
  --ui-sp-6: 48px;

  /* Border */
  --ui-radius-sm:  4px;
  --ui-radius:     8px;
  --ui-radius-lg:  12px;
  --ui-radius-xl:  20px;
  --ui-radius-pill:999px;
  --ui-border:     1px solid var(--ui-gray-200);

  /* Shadow */
  --ui-shadow-sm: 0 1px 4px rgba(0,0,0,.06);
  --ui-shadow:    0 2px 12px rgba(0,0,0,.08);
  --ui-shadow-lg: 0 4px 24px rgba(0,0,0,.10);

  /* Transition */
  --ui-transition: 0.2s ease;
}


/* ==========================================================================
   2. SCOPE RESET
   ========================================================================== */

.ui-scope *,
.ui-scope *::before,
.ui-scope *::after {
  box-sizing: border-box;
}


/* ==========================================================================
   3. HERO SECTION
   ========================================================================== */

.ui-hero {
  position: relative;
  background: var(--ui-accent);
  color: var(--ui-white);
  padding: clamp(var(--ui-sp-4), 8vw, var(--ui-sp-6)) clamp(var(--ui-sp-2), 5vw, var(--ui-sp-4));
  border-radius: var(--ui-radius-lg);
  overflow: hidden;
  margin-bottom: var(--ui-sp-4);
}

.ui-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--ui-accent) 60%, var(--ui-accent-light) 100%);
  z-index: 0;
}

.ui-hero__inner {
  position: relative;
  z-index: 1;
}

.ui-hero__eyebrow {
  display: inline-block;
  font-size: var(--ui-font-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ui-accent-sub);
  margin-bottom: var(--ui-sp-1);
}

.ui-hero__title {
  font-size: var(--ui-font-h);
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 var(--ui-sp-2);
  color: var(--ui-white);
}

.ui-hero__lead {
  font-size: var(--ui-font-base);
  line-height: 1.8;
  color: rgba(255,255,255,.85);
  margin: 0;
}

.ui-hero--light {
  background: var(--ui-accent-pale);
  color: var(--ui-accent);
}

.ui-hero--light::before {
  background: linear-gradient(135deg, var(--ui-accent-pale) 60%, var(--ui-accent-sub-light) 100%);
}

.ui-hero--light .ui-hero__title {
  color: var(--ui-accent);
}

.ui-hero--light .ui-hero__lead {
  color: var(--ui-gray-700);
}


/* ==========================================================================
   4. BRAND AUTH PILL
   ========================================================================== */

.ui-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--ui-sp-1);
  padding: 4px var(--ui-sp-2);
  background: var(--ui-accent-sub-light);
  border: 1px solid var(--ui-accent-sub);
  border-radius: var(--ui-radius-pill);
  font-size: var(--ui-font-xs);
  font-weight: 600;
  color: var(--ui-accent);
  letter-spacing: 0.04em;
}

.ui-pill__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.ui-pill--accent {
  background: var(--ui-accent);
  border-color: var(--ui-accent);
  color: var(--ui-white);
}

.ui-pill--success {
  background: var(--ui-success-bg);
  border-color: var(--ui-success);
  color: var(--ui-success);
}


/* ==========================================================================
   5. PRODUCT IMAGE BLOCK
   ========================================================================== */

.ui-product-img {
  position: relative;
  display: block;
  border-radius: var(--ui-radius-lg);
  overflow: hidden;
  background: var(--ui-gray-50);
  box-shadow: var(--ui-shadow);
  margin-bottom: var(--ui-sp-3);
}

.ui-product-img img {
  width: 100%;
  height: auto;
  display: block;
}

.ui-product-img__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--ui-sp-1) var(--ui-sp-2);
  background: rgba(27,42,74,.75);
  color: var(--ui-white);
  font-size: var(--ui-font-xs);
  text-align: center;
}

/* 画像注釈 */
.ui-product-img.is-image-note {
  position: relative;
}

.ui-product-img.is-image-note::after {
  content: '※画像はイメージです';
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 3px 8px;
  background: rgba(0,0,0,.5);
  color: var(--ui-white);
  font-size: 10px;
  border-top-left-radius: var(--ui-radius-sm);
  pointer-events: none;
}


/* ==========================================================================
   6. SUMMARY BOX
   ========================================================================== */

.ui-summary {
  border: 2px solid var(--ui-accent);
  border-radius: var(--ui-radius-lg);
  overflow: hidden;
  margin-bottom: var(--ui-sp-4);
}

.ui-summary__head {
  background: var(--ui-accent);
  color: var(--ui-white);
  padding: var(--ui-sp-1) var(--ui-sp-3);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  gap: var(--ui-sp-1);
}

.ui-summary__body {
  padding: var(--ui-sp-3);
  background: var(--ui-white);
}

.ui-summary__body ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ui-summary__body ul li {
  padding: 6px 0 6px var(--ui-sp-3);
  position: relative;
  font-size: var(--ui-font-base);
  line-height: 1.7;
  border-bottom: 1px solid var(--ui-gray-100);
}

.ui-summary__body ul li:last-child {
  border-bottom: none;
}

.ui-summary__body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ui-accent-sub);
}


/* ==========================================================================
   7. COMPARE CARD
   ========================================================================== */

.ui-compare {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ui-sp-2);
  margin-bottom: var(--ui-sp-4);
}

@media (min-width: 768px) {
  .ui-compare {
    grid-template-columns: 1fr 1fr;
  }
}

.ui-compare__item {
  border: var(--ui-border);
  border-radius: var(--ui-radius-lg);
  overflow: hidden;
  box-shadow: var(--ui-shadow-sm);
}

.ui-compare__head {
  padding: var(--ui-sp-2) var(--ui-sp-3);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  text-align: center;
  background: var(--ui-gray-100);
  color: var(--ui-gray-900);
}

.ui-compare__item--a .ui-compare__head {
  background: var(--ui-accent);
  color: var(--ui-white);
}

.ui-compare__item--b .ui-compare__head {
  background: var(--ui-accent-sub);
  color: var(--ui-accent);
}

.ui-compare__body {
  padding: var(--ui-sp-3);
  background: var(--ui-white);
}

.ui-compare__body ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ui-compare__body ul li {
  padding: 5px 0 5px var(--ui-sp-3);
  position: relative;
  font-size: var(--ui-font-sm);
  line-height: 1.7;
}

.ui-compare__body ul li::before {
  content: '▶';
  position: absolute;
  left: 0;
  top: 6px;
  font-size: 10px;
  color: var(--ui-accent-sub-dark);
}


/* ==========================================================================
   8. RESPONSIVE TABLE
   ========================================================================== */

.ui-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: var(--ui-sp-4);
  border-radius: var(--ui-radius);
  box-shadow: var(--ui-shadow-sm);
}

.ui-table {
  width: 100%;
  min-width: 480px;
  border-collapse: collapse;
  font-size: var(--ui-font-sm);
  background: var(--ui-white);
}

.ui-table th,
.ui-table td {
  padding: var(--ui-sp-2) var(--ui-sp-2);
  text-align: left;
  border-bottom: 1px solid var(--ui-gray-200);
  vertical-align: middle;
  white-space: nowrap;
}

.ui-table th {
  background: var(--ui-accent);
  color: var(--ui-white);
  font-weight: 600;
  font-size: var(--ui-font-xs);
  letter-spacing: 0.04em;
}

.ui-table tr:last-child td {
  border-bottom: none;
}

.ui-table tr:nth-child(even) td {
  background: var(--ui-gray-50);
}

.ui-table td:first-child {
  font-weight: 600;
  color: var(--ui-accent);
}

.ui-table--highlight td.is-best {
  background: var(--ui-accent-sub-light);
  font-weight: 700;
}


/* ==========================================================================
   9. BAR CHART
   ========================================================================== */

.ui-bar-chart {
  display: flex;
  flex-direction: column;
  gap: var(--ui-sp-1);
  margin-bottom: var(--ui-sp-4);
}

.ui-bar-chart__row {
  display: flex;
  align-items: center;
  gap: var(--ui-sp-2);
}

.ui-bar-chart__label {
  flex-shrink: 0;
  width: clamp(80px, 20%, 140px);
  font-size: var(--ui-font-sm);
  font-weight: 600;
  color: var(--ui-gray-700);
  text-align: right;
}

.ui-bar-chart__bar-wrap {
  flex: 1;
  background: var(--ui-gray-100);
  border-radius: var(--ui-radius-pill);
  overflow: hidden;
  height: 28px;
}

.ui-bar-chart__bar {
  width: var(--bar-pct, 0%);
  height: 100%;
  background: linear-gradient(90deg, var(--ui-accent), var(--ui-accent-light));
  border-radius: var(--ui-radius-pill);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  animation: ui-bar-grow 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.ui-bar-chart__value {
  padding-right: var(--ui-sp-1);
  font-size: var(--ui-font-xs);
  font-weight: 700;
  color: var(--ui-white);
  white-space: nowrap;
}

@keyframes ui-bar-grow {
  from { width: 0%; }
  to   { width: var(--bar-pct, 0%); }
}

.ui-bar-chart__bar--sub {
  background: linear-gradient(90deg, var(--ui-accent-sub-dark), var(--ui-accent-sub));
}

.ui-bar-chart__bar--sub .ui-bar-chart__value {
  color: var(--ui-accent);
}


/* ==========================================================================
   10. CARD GRID
   ========================================================================== */

.ui-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ui-sp-2);
  margin-bottom: var(--ui-sp-4);
}

@media (min-width: 768px) {
  .ui-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ui-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.ui-card {
  background: var(--ui-white);
  border: var(--ui-border);
  border-radius: var(--ui-radius-lg);
  padding: var(--ui-sp-3);
  box-shadow: var(--ui-shadow-sm);
  transition: box-shadow var(--ui-transition), transform var(--ui-transition);
}

.ui-card:hover {
  box-shadow: var(--ui-shadow);
  transform: translateY(-2px);
}

.ui-card__label {
  display: inline-block;
  font-size: var(--ui-font-xs);
  font-weight: 700;
  color: var(--ui-accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--ui-sp-1);
}

.ui-card__title {
  font-size: clamp(1rem, 2.5vw, 1.125rem);
  font-weight: 700;
  line-height: 1.5;
  color: var(--ui-gray-900);
  margin: 0 0 var(--ui-sp-1);
}

.ui-card__body {
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  margin: 0;
}

.ui-card--highlight {
  border-color: var(--ui-accent);
  border-left: 4px solid var(--ui-accent);
}

.ui-card--sub {
  border-color: var(--ui-accent-sub);
  border-left: 4px solid var(--ui-accent-sub);
}


/* ==========================================================================
   11. TIMELINE
   ========================================================================== */

.ui-timeline {
  position: relative;
  padding-left: clamp(var(--ui-sp-4), 8vw, 56px);
  margin-bottom: var(--ui-sp-4);
}

.ui-timeline::before {
  content: '';
  position: absolute;
  left: 16px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--ui-gray-200);
}

.ui-timeline__item {
  position: relative;
  margin-bottom: var(--ui-sp-3);
}

.ui-timeline__item:last-child {
  margin-bottom: 0;
}

.ui-timeline__dot {
  position: absolute;
  left: calc(-1 * clamp(var(--ui-sp-4), 8vw, 56px) + 8px);
  top: 4px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--ui-accent);
  border: 3px solid var(--ui-white);
  box-shadow: 0 0 0 2px var(--ui-accent);
  z-index: 1;
}

.ui-timeline__date {
  font-size: var(--ui-font-xs);
  font-weight: 700;
  color: var(--ui-accent-sub-dark);
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.ui-timeline__title {
  font-size: var(--ui-font-base);
  font-weight: 700;
  color: var(--ui-gray-900);
  margin: 0 0 4px;
}

.ui-timeline__body {
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  margin: 0;
}


/* ==========================================================================
   12. STEP UI
   ========================================================================== */

.ui-steps {
  counter-reset: ui-step;
  margin-bottom: var(--ui-sp-4);
}

.ui-step {
  display: flex;
  gap: var(--ui-sp-3);
  padding-bottom: var(--ui-sp-3);
  position: relative;
}

.ui-step:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 19px;
  top: 48px;
  bottom: 0;
  width: 2px;
  background: var(--ui-gray-200);
}

.ui-step__num {
  counter-increment: ui-step;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--ui-accent);
  color: var(--ui-white);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.ui-step__num::before {
  content: counter(ui-step);
}

.ui-step__content {
  flex: 1;
  padding-top: 8px;
}

.ui-step__title {
  font-size: var(--ui-font-base);
  font-weight: 700;
  color: var(--ui-accent);
  margin: 0 0 var(--ui-sp-1);
}

.ui-step__body {
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  margin: 0;
}


/* ==========================================================================
   13. BADGE
   ========================================================================== */

.ui-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 10px;
  border-radius: var(--ui-radius-pill);
  font-size: var(--ui-font-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
  background: var(--ui-accent);
  color: var(--ui-white);
}

.ui-badge--sub {
  background: var(--ui-accent-sub);
  color: var(--ui-accent);
}

.ui-badge--success {
  background: var(--ui-success-bg);
  color: var(--ui-success);
  border: 1px solid var(--ui-success);
}

.ui-badge--warn {
  background: var(--ui-warn-bg);
  color: var(--ui-warn);
  border: 1px solid var(--ui-warn);
}

.ui-badge--danger {
  background: var(--ui-danger-bg);
  color: var(--ui-danger);
  border: 1px solid var(--ui-danger);
}

.ui-badge--outline {
  background: transparent;
  color: var(--ui-accent);
  border: 1px solid var(--ui-accent);
}


/* ==========================================================================
   14. MERIT / DEMERIT
   ========================================================================== */

.ui-merit-wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ui-sp-2);
  margin-bottom: var(--ui-sp-4);
}

@media (min-width: 768px) {
  .ui-merit-wrap {
    grid-template-columns: 1fr 1fr;
  }
}

.ui-merit,
.ui-demerit {
  border-radius: var(--ui-radius-lg);
  overflow: hidden;
  box-shadow: var(--ui-shadow-sm);
}

.ui-merit__head,
.ui-demerit__head {
  padding: var(--ui-sp-1) var(--ui-sp-3);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 6px;
}

.ui-merit__head {
  background: var(--ui-success);
  color: var(--ui-white);
}

.ui-demerit__head {
  background: var(--ui-danger);
  color: var(--ui-white);
}

.ui-merit__body,
.ui-demerit__body {
  padding: var(--ui-sp-2) var(--ui-sp-3);
  background: var(--ui-white);
}

.ui-merit__body ul,
.ui-demerit__body ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ui-merit__body ul li,
.ui-demerit__body ul li {
  padding: 5px 0 5px var(--ui-sp-3);
  position: relative;
  font-size: var(--ui-font-sm);
  line-height: 1.7;
}

.ui-merit__body ul li::before {
  content: '○';
  position: absolute;
  left: 0;
  top: 5px;
  color: var(--ui-success);
  font-size: var(--ui-font-xs);
  font-weight: 700;
}

.ui-demerit__body ul li::before {
  content: '×';
  position: absolute;
  left: 0;
  top: 5px;
  color: var(--ui-danger);
  font-size: var(--ui-font-xs);
  font-weight: 700;
}


/* ==========================================================================
   15. FAQ (Static)
   ========================================================================== */

.ui-faq {
  margin-bottom: var(--ui-sp-4);
}

.ui-faq__item {
  border: var(--ui-border);
  border-radius: var(--ui-radius-lg);
  margin-bottom: var(--ui-sp-2);
  overflow: hidden;
}

.ui-faq__q {
  display: flex;
  align-items: flex-start;
  gap: var(--ui-sp-2);
  padding: var(--ui-sp-2) var(--ui-sp-3);
  background: var(--ui-accent-pale);
}

.ui-faq__q-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--ui-accent);
  color: var(--ui-white);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ui-faq__q-text {
  font-size: var(--ui-font-base);
  font-weight: 700;
  line-height: 1.6;
  color: var(--ui-accent);
  padding-top: 4px;
}

.ui-faq__a {
  display: flex;
  align-items: flex-start;
  gap: var(--ui-sp-2);
  padding: var(--ui-sp-2) var(--ui-sp-3);
  background: var(--ui-white);
}

.ui-faq__a-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--ui-accent-sub);
  color: var(--ui-accent);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ui-faq__a-text {
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  padding-top: 4px;
}


/* ==========================================================================
   16. REVIEW / VOICE
   ========================================================================== */

.ui-review {
  border: var(--ui-border);
  border-radius: var(--ui-radius-lg);
  padding: var(--ui-sp-3);
  background: var(--ui-white);
  box-shadow: var(--ui-shadow-sm);
  margin-bottom: var(--ui-sp-3);
  position: relative;
}

.ui-review__header {
  display: flex;
  align-items: center;
  gap: var(--ui-sp-2);
  margin-bottom: var(--ui-sp-2);
}

.ui-review__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--ui-accent-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--ui-font-sm);
  font-weight: 700;
  color: var(--ui-accent);
  flex-shrink: 0;
  overflow: hidden;
}

.ui-review__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ui-review__meta {
  flex: 1;
}

.ui-review__name {
  font-size: var(--ui-font-sm);
  font-weight: 700;
  color: var(--ui-gray-900);
  margin: 0 0 2px;
}

.ui-review__stars {
  color: var(--ui-amazon);
  font-size: var(--ui-font-sm);
  letter-spacing: 1px;
}

.ui-review__body {
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  margin: 0;
}

.ui-review__tag {
  display: inline-block;
  margin-top: var(--ui-sp-1);
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-500);
}


/* ==========================================================================
   17. CTA BOX
   ========================================================================== */

.ui-cta {
  background: var(--ui-accent-pale);
  border: 2px solid var(--ui-accent);
  border-radius: var(--ui-radius-lg);
  padding: clamp(var(--ui-sp-3), 5vw, var(--ui-sp-5));
  text-align: center;
  margin-bottom: var(--ui-sp-4);
}

.ui-cta__label {
  display: inline-block;
  font-size: var(--ui-font-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ui-accent-sub-dark);
  margin-bottom: var(--ui-sp-1);
}

.ui-cta__title {
  font-size: var(--ui-font-h);
  font-weight: 700;
  color: var(--ui-accent);
  line-height: 1.4;
  margin: 0 0 var(--ui-sp-1);
}

.ui-cta__lead {
  font-size: var(--ui-font-sm);
  color: var(--ui-gray-700);
  line-height: 1.8;
  margin: 0 0 var(--ui-sp-3);
}

/* Button Group */
.ui-btn-group {
  display: flex;
  flex-direction: column;
  gap: var(--ui-sp-2);
  align-items: stretch;
}

@media (min-width: 768px) {
  .ui-btn-group {
    flex-direction: row;
    justify-content: center;
    align-items: center;
  }

  .ui-btn-group--col {
    flex-direction: column;
    align-items: center;
  }
}

/* Base Button */
.ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ui-sp-1);
  min-height: 52px;
  padding: 0 var(--ui-sp-4);
  border-radius: var(--ui-radius);
  font-size: var(--ui-font-base);
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--ui-transition), transform var(--ui-transition), box-shadow var(--ui-transition);
  border: none;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.ui-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--ui-shadow);
}

.ui-btn:active {
  transform: translateY(0);
  box-shadow: none;
}

/* Amazon Button */
.ui-btn--amazon {
  background: var(--ui-amazon);
  color: var(--ui-amazon-text);
  box-shadow: 0 2px 6px rgba(255,153,0,.3);
}

.ui-btn--amazon:hover {
  background: var(--ui-amazon-dark);
  color: var(--ui-amazon-text);
  box-shadow: 0 4px 12px rgba(255,153,0,.4);
  text-decoration: none;
}

.ui-btn--amazon:active {
  background: #CC7A00;
}

/* Rakuten Button */
.ui-btn--rakuten {
  background: var(--ui-rakuten);
  color: var(--ui-rakuten-text);
  box-shadow: 0 2px 6px rgba(191,0,0,.25);
}

.ui-btn--rakuten:hover {
  background: var(--ui-rakuten-dark);
  color: var(--ui-rakuten-text);
  box-shadow: 0 4px 12px rgba(191,0,0,.35);
  text-decoration: none;
}

.ui-btn--rakuten:active {
  background: #800000;
}

/* Accent Button */
.ui-btn--accent {
  background: var(--ui-accent);
  color: var(--ui-white);
  box-shadow: 0 2px 6px rgba(27,42,74,.2);
}

.ui-btn--accent:hover {
  background: var(--ui-accent-light);
  color: var(--ui-white);
  text-decoration: none;
}

/* Ghost Button */
.ui-btn--ghost {
  background: transparent;
  color: var(--ui-accent);
  border: 2px solid var(--ui-accent);
}

.ui-btn--ghost:hover {
  background: var(--ui-accent);
  color: var(--ui-white);
}

/* Full Width */
.ui-btn--full {
  width: 100%;
}

/* Button Icon */
.ui-btn__icon {
  font-size: 1.1em;
  line-height: 1;
}


/* ==========================================================================
   18. CONCLUSION BOX
   ========================================================================== */

.ui-conclusion {
  background: var(--ui-accent);
  color: var(--ui-white);
  border-radius: var(--ui-radius-lg);
  padding: clamp(var(--ui-sp-3), 5vw, var(--ui-sp-4));
  margin-bottom: var(--ui-sp-4);
}

.ui-conclusion__head {
  display: flex;
  align-items: center;
  gap: var(--ui-sp-1);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ui-accent-sub);
  margin-bottom: var(--ui-sp-2);
}

.ui-conclusion__title {
  font-size: var(--ui-font-h);
  font-weight: 700;
  line-height: 1.4;
  color: var(--ui-white);
  margin: 0 0 var(--ui-sp-2);
}

.ui-conclusion__body {
  font-size: var(--ui-font-sm);
  line-height: 1.9;
  color: rgba(255,255,255,.85);
  margin: 0;
}


/* ==========================================================================
   19. ARTICLE FOOTER (記事末尾締めフッター)
   ========================================================================== */

.ui-article-footer {
  border-top: 2px solid var(--ui-gray-200);
  padding-top: var(--ui-sp-4);
  margin-top: var(--ui-sp-5);
}

.ui-article-footer__title {
  font-size: var(--ui-font-sm);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ui-gray-500);
  margin-bottom: var(--ui-sp-2);
  text-align: center;
}

.ui-article-footer__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ui-sp-1);
  justify-content: center;
  margin-bottom: var(--ui-sp-3);
}

.ui-article-footer__tag {
  display: inline-block;
  padding: 4px var(--ui-sp-2);
  border: var(--ui-border);
  border-radius: var(--ui-radius-pill);
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-700);
  text-decoration: none;
  transition: background var(--ui-transition), color var(--ui-transition);
}

.ui-article-footer__tag:hover {
  background: var(--ui-accent);
  color: var(--ui-white);
  border-color: var(--ui-accent);
  text-decoration: none;
}

.ui-article-footer__note {
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-500);
  line-height: 1.8;
  text-align: center;
  border-top: var(--ui-border);
  padding-top: var(--ui-sp-2);
  margin-top: var(--ui-sp-2);
}


/* ==========================================================================
   20. INFO / WARN BOX
   ========================================================================== */

.ui-box {
  border-radius: var(--ui-radius-lg);
  padding: var(--ui-sp-2) var(--ui-sp-3);
  margin-bottom: var(--ui-sp-3);
  display: flex;
  gap: var(--ui-sp-2);
  align-items: flex-start;
}

.ui-box__icon {
  flex-shrink: 0;
  font-size: 1.25rem;
  line-height: 1.6;
}

.ui-box__body {
  flex: 1;
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-900);
}

.ui-box__body strong {
  display: block;
  font-weight: 700;
  margin-bottom: 2px;
}

.ui-box--info {
  background: var(--ui-info-bg);
  border: 1px solid var(--ui-info-border);
}

.ui-box--info .ui-box__icon { color: var(--ui-info); }

.ui-box--warn {
  background: var(--ui-warn-bg);
  border: 1px solid var(--ui-warn-border);
}

.ui-box--warn .ui-box__icon { color: var(--ui-warn); }

.ui-box--success {
  background: var(--ui-success-bg);
  border: 1px solid var(--ui-success);
}

.ui-box--success .ui-box__icon { color: var(--ui-success); }

.ui-box--danger {
  background: var(--ui-danger-bg);
  border: 1px solid var(--ui-danger);
}

.ui-box--danger .ui-box__icon { color: var(--ui-danger); }

.ui-box--accent {
  background: var(--ui-accent-pale);
  border: 1px solid var(--ui-accent);
}

.ui-box--accent .ui-box__icon { color: var(--ui-accent); }


/* ==========================================================================
   21. SECTION DIVIDER
   ========================================================================== */

.ui-divider {
  display: flex;
  align-items: center;
  gap: var(--ui-sp-2);
  margin: var(--ui-sp-4) 0;
  color: var(--ui-gray-500);
  font-size: var(--ui-font-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.ui-divider::before,
.ui-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ui-gray-200);
}

.ui-divider--accent {
  color: var(--ui-accent);
}

.ui-divider--accent::before,
.ui-divider--accent::after {
  background: var(--ui-accent);
  opacity: 0.3;
}

.ui-divider--thick {
  margin: var(--ui-sp-5) 0;
}

.ui-divider--thick::before,
.ui-divider--thick::after {
  height: 2px;
}


/* ==========================================================================
   22. MARKER / HIGHLIGHT
   ========================================================================== */

.ui-mark {
  background: linear-gradient(transparent 50%, rgba(217,191,163,.5) 50%);
  padding: 0 2px;
}

.ui-mark--yellow {
  background: linear-gradient(transparent 50%, rgba(255,236,61,.6) 50%);
}

.ui-mark--blue {
  background: linear-gradient(transparent 50%, rgba(191,219,254,.7) 50%);
}

.ui-mark--green {
  background: linear-gradient(transparent 50%, rgba(167,243,208,.7) 50%);
}

.ui-mark--pink {
  background: linear-gradient(transparent 50%, rgba(251,207,232,.7) 50%);
}

.ui-mark--accent {
  background: linear-gradient(transparent 50%, rgba(27,42,74,.15) 50%);
}


/* ==========================================================================
   23. INLINE BADGE
   ========================================================================== */

.ui-tag {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  border-radius: var(--ui-radius-sm);
  font-size: var(--ui-font-xs);
  font-weight: 700;
  line-height: 1.8;
  background: var(--ui-accent-pale);
  color: var(--ui-accent);
  border: 1px solid var(--ui-accent);
  vertical-align: middle;
}

.ui-tag--new    { background: #FEF9C3; color: #854D0E; border-color: #FDE047; }
.ui-tag--hot    { background: #FEE2E2; color: #991B1B; border-color: #FCA5A5; }
.ui-tag--sale   { background: #DCFCE7; color: #166534; border-color: #86EFAC; }
.ui-tag--pickup { background: var(--ui-accent-sub-light); color: var(--ui-accent); border-color: var(--ui-accent-sub); }


/* ==========================================================================
   24. BLOCKQUOTE EXTENSION
   ========================================================================== */

.ui-quote {
  position: relative;
  padding: var(--ui-sp-3) var(--ui-sp-3) var(--ui-sp-3) calc(var(--ui-sp-4) + 4px);
  border-left: 4px solid var(--ui-accent-sub);
  background: var(--ui-gray-50);
  border-radius: 0 var(--ui-radius) var(--ui-radius) 0;
  margin-bottom: var(--ui-sp-3);
}

.ui-quote::before {
  content: '\201C';
  position: absolute;
  top: -8px;
  left: var(--ui-sp-2);
  font-size: 4rem;
  line-height: 1;
  color: var(--ui-accent-sub);
  font-family: Georgia, serif;
  opacity: 0.6;
}

.ui-quote__body {
  font-size: var(--ui-font-base);
  line-height: 1.9;
  color: var(--ui-gray-700);
  font-style: italic;
  margin: 0 0 var(--ui-sp-1);
}

.ui-quote__cite {
  display: block;
  font-size: var(--ui-font-xs);
  font-style: normal;
  font-weight: 700;
  color: var(--ui-gray-500);
  text-align: right;
}


/* ==========================================================================
   25. CODE BLOCK
   ========================================================================== */

.ui-code {
  background: var(--ui-gray-900);
  color: #E2E8F0;
  border-radius: var(--ui-radius);
  padding: var(--ui-sp-3);
  overflow-x: auto;
  font-family: 'Courier New', Courier, monospace;
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  margin-bottom: var(--ui-sp-3);
  -webkit-overflow-scrolling: touch;
}

.ui-code--inline {
  display: inline;
  padding: 2px 6px;
  border-radius: var(--ui-radius-sm);
  background: var(--ui-gray-100);
  color: var(--ui-danger);
  font-family: 'Courier New', Courier, monospace;
  font-size: 0.85em;
}


/* ==========================================================================
   26. LABELED LIST
   ========================================================================== */

.ui-list {
  margin-bottom: var(--ui-sp-4);
}

.ui-list__item {
  display: flex;
  gap: var(--ui-sp-2);
  align-items: flex-start;
  padding: var(--ui-sp-1) 0;
  border-bottom: 1px solid var(--ui-gray-100);
}

.ui-list__item:last-child {
  border-bottom: none;
}

.ui-list__label {
  flex-shrink: 0;
  min-width: 80px;
  font-size: var(--ui-font-xs);
  font-weight: 700;
  color: var(--ui-white);
  background: var(--ui-accent);
  padding: 2px 8px;
  border-radius: var(--ui-radius-sm);
  text-align: center;
  line-height: 1.8;
}

.ui-list__label--sub {
  background: var(--ui-accent-sub);
  color: var(--ui-accent);
}

.ui-list__value {
  flex: 1;
  font-size: var(--ui-font-sm);
  line-height: 1.8;
  color: var(--ui-gray-700);
  padding-top: 2px;
}


/* ==========================================================================
   27. INTERNAL LINK CARD
   ========================================================================== */

.ui-link-card {
  display: flex;
  align-items: center;
  gap: var(--ui-sp-2);
  padding: var(--ui-sp-2) var(--ui-sp-3);
  border: var(--ui-border);
  border-left: 4px solid var(--ui-accent);
  border-radius: var(--ui-radius);
  background: var(--ui-white);
  text-decoration: none;
  transition: background var(--ui-transition), box-shadow var(--ui-transition);
  margin-bottom: var(--ui-sp-2);
  box-shadow: var(--ui-shadow-sm);
}

.ui-link-card:hover {
  background: var(--ui-accent-pale);
  box-shadow: var(--ui-shadow);
  text-decoration: none;
}

.ui-link-card__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--ui-radius);
  background: var(--ui-accent-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ui-accent);
  font-size: 1.1rem;
}

.ui-link-card__body {
  flex: 1;
  min-width: 0;
}

.ui-link-card__label {
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-500);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 2px;
}

.ui-link-card__title {
  font-size: var(--ui-font-sm);
  font-weight: 700;
  color: var(--ui-accent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ui-link-card__arrow {
  flex-shrink: 0;
  color: var(--ui-gray-300);
  font-size: 1rem;
}


/* ==========================================================================
   28. RANKING LIST
   ========================================================================== */

.ui-ranking {
  margin-bottom: var(--ui-sp-4);
}

.ui-ranking__item {
  display: flex;
  align-items: flex-start;
  gap: var(--ui-sp-2);
  padding: var(--ui-sp-2) 0;
  border-bottom: 1px solid var(--ui-gray-100);
}

.ui-ranking__item:last-child {
  border-bottom: none;
}

.ui-ranking__num {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--ui-gray-200);
  color: var(--ui-gray-700);
  font-size: var(--ui-font-sm);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ui-ranking__item:nth-child(1) .ui-ranking__num {
  background: #C8973A;
  color: var(--ui-white);
}

.ui-ranking__item:nth-child(2) .ui-ranking__num {
  background: #9EA8B0;
  color: var(--ui-white);
}

.ui-ranking__item:nth-child(3) .ui-ranking__num {
  background: #A0785A;
  color: var(--ui-white);
}

.ui-ranking__body {
  flex: 1;
}

.ui-ranking__title {
  font-size: var(--ui-font-base);
  font-weight: 700;
  color: var(--ui-gray-900);
  margin: 0 0 2px;
}

.ui-ranking__desc {
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-500);
  line-height: 1.6;
  margin: 0;
}

.ui-ranking__stars {
  font-size: var(--ui-font-sm);
  color: var(--ui-amazon);
}


/* ==========================================================================
   29. CHECKLIST
   ========================================================================== */

.ui-checklist {
  margin-bottom: var(--ui-sp-4);
}

.ui-checklist__item {
  display: flex;
  align-items: flex-start;
  gap: var(--ui-sp-2);
  padding: 6px 0;
  font-size: var(--ui-font-sm);
  line-height: 1.7;
  color: var(--ui-gray-700);
}

.ui-checklist__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ui-success);
  color: var(--ui-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  margin-top: 2px;
}

.ui-checklist__icon::before {
  content: '✓';
  font-weight: 700;
}

.ui-checklist__item--check .ui-checklist__icon {
  background: var(--ui-success);
}

.ui-checklist__item--cross .ui-checklist__icon {
  background: var(--ui-danger);
}

.ui-checklist__item--cross .ui-checklist__icon::before {
  content: '✕';
}

.ui-checklist__item--warn .ui-checklist__icon {
  background: var(--ui-warn);
}

.ui-checklist__item--warn .ui-checklist__icon::before {
  content: '!';
}


/* ==========================================================================
   30. SCROLL HINT
   ========================================================================== */

.ui-scroll-hint {
  position: relative;
}

.ui-scroll-hint::after {
  content: '← 横にスクロールできます →';
  display: block;
  text-align: center;
  font-size: var(--ui-font-xs);
  color: var(--ui-gray-500);
  padding: 6px 0 0;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .ui-scroll-hint::after {
    display: none;
  }
}


/* ==========================================================================
   31. IMAGE TAP HINT
   ========================================================================== */

.ui-tap-hint {
  position: relative;
  display: block;
}

.ui-tap-hint::after {
  content: 'タップで拡大';
  position: absolute;
  bottom: var(--ui-sp-1);
  right: var(--ui-sp-1);
  background: rgba(0,0,0,.55);
  color: var(--ui-white);
  font-size: 10px;
  padding: 3px 8px;
  border-radius: var(--ui-radius-pill);
  pointer-events: none;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .ui-tap-hint::after {
    display: none;
  }
}


/* ==========================================================================
   32. IMAGE NOTE
   ========================================================================== */

.is-image-note {
  position: relative;
  display: block;
}

.is-image-note::after {
  content: '※画像はイメージです';
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 3px 10px;
  background: rgba(0,0,0,.48);
  color: var(--ui-white);
  font-size: 10px;
  letter-spacing: 0.03em;
  border-top-left-radius: var(--ui-radius-sm);
  pointer-events: none;
}


/* ==========================================================================
   33. SKELETON UI
   ========================================================================== */

@keyframes ui-skeleton-fade {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.45; }
}

.ui-skeleton {
  border-radius: var(--ui-radius);
  background: var(--ui-gray-200);
  animation: ui-skeleton-fade 1.4s ease-in-out infinite;
}

.ui-skeleton--text {
  height: 1em;
  border-radius: var(--ui-radius-sm);
  margin-bottom: var(--ui-sp-1);
}

.ui-skeleton--text-short {
  width: 60%;
}

.ui-skeleton--title {
  height: 1.5em;
  margin-bottom: var(--ui-sp-2);
}

.ui-skeleton--img {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.ui-skeleton--circle {
  border-radius: 50%;
  width: 44px;
  height: 44px;
}

.ui-skeleton--btn {
  height: 52px;
  width: 180px;
}


/* ==========================================================================
   34. RESPONSIVE UTILITIES
   ========================================================================== */

@media (max-width: 767px) {
  .ui-hide-sp { display: none; }
}

@media (min-width: 768px) {
  .ui-hide-pc { display: none; }
}

.ui-text-center { text-align: center; }
.ui-text-left   { text-align: left; }
.ui-mt-0 { margin-top: 0; }
.ui-mb-0 { margin-bottom: 0; }
.ui-mt-2 { margin-top: var(--ui-sp-2); }
.ui-mb-2 { margin-bottom: var(--ui-sp-2); }
.ui-mt-4 { margin-top: var(--ui-sp-4); }
.ui-mb-4 { margin-bottom: var(--ui-sp-4); }
