/* ===========================================
   Main Styles - ReamMeister Drawing App
   =========================================== */

/* ===========================================
   Layout
   =========================================== */

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh; /* Dynamic viewport height for mobile */
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: var(--header-height);
  padding: 0 var(--spacing-6);
  background-color: var(--color-header-bg, #1f1f1f);
  color: var(--color-header-text, #ffffff);
  box-shadow: var(--shadow-md);
}

.header__brand {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
}

.header__logo {
  height: 40px;
  width: auto;
}

.header__title-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.header__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
}

.header__subtitle {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.2;
}

.header__controls {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
}

.header__version {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.6);
  padding: var(--spacing-1) var(--spacing-2);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-sm);
}

.main {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--spacing-6);
  padding: var(--spacing-6);
  overflow: auto;
}

.footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-2);
  padding: var(--spacing-4) var(--spacing-6);
  background-color: var(--color-header-bg, #1f1f1f);
  color: var(--color-gray-400);
  font-size: var(--font-size-sm);
  flex-shrink: 0;
  margin-top: auto;
}

.footer__nav {
  display: flex;
  gap: var(--spacing-6);
  flex-wrap: wrap;
  justify-content: center;
}

.footer__link {
  color: var(--color-gray-300);
  text-decoration: none;
  font-size: var(--font-size-sm);
  transition: color var(--transition-fast);
}

.footer__link:hover {
  color: var(--color-white);
  text-decoration: underline;
}

.footer__copyright {
  color: var(--color-gray-500);
  font-size: var(--font-size-xs);
}

/* ===========================================
   Input Area
   =========================================== */

.input-area {
  width: 100%;
  max-width: 100%;
  overflow-y: visible;
  padding-right: 0;
}

/* ===========================================
   4列レイアウト（ワーク情報 + 工具詳細情報）
   =========================================== */

/* 2つのfieldsetを横並びにするコンテナ */
.form-sections-container {
  display: flex;
  gap: var(--spacing-4);
  align-items: stretch;
}

.form-sections-container > .fieldset {
  flex: 1;
  margin-bottom: 0;
}

/* ワーク情報: 2列構成 */
.work-info-columns {
  display: flex;
  gap: var(--spacing-4);
}

.work-col {
  flex: 1;
  min-width: 0;
}

.work-col--hole-type {
  flex: 0 0 180px;
  max-width: 180px;
}

.work-col--dimensions {
  flex: 1;
}

/* 工具詳細情報: 2列構成 */
.tool-detail-columns {
  display: flex;
  gap: var(--spacing-4);
}

.tool-col {
  flex: 1;
  min-width: 0;
}

/* 列ヘッダー */
.col-header {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  margin-bottom: var(--spacing-3);
  padding-bottom: var(--spacing-2);
  border-bottom: 2px solid var(--color-primary-light);
}

/* 必須マーク */
.required {
  color: var(--color-error);
}

/* ===========================================
   穴タイプ選択カード
   =========================================== */

.hole-type-selector {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}

.hole-type-option {
  cursor: pointer;
}

.hole-type-option input[type="radio"] {
  display: none;
}

.hole-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--spacing-2);
  border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  background-color: var(--color-white);
  transition: all var(--transition-fast);
}

.hole-type-card:hover {
  border-color: var(--color-primary-light);
  background-color: var(--color-gray-50);
}

.hole-type-option input[type="radio"]:checked + .hole-type-card {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.hole-type-card__img {
  width: 100%;
  max-width: 120px;
  height: auto;
  border-radius: var(--radius-sm);
  margin-bottom: var(--spacing-1);
}

.hole-type-card__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-700);
}

.hole-type-option input[type="radio"]:checked + .hole-type-card .hole-type-card__label {
  color: var(--color-primary);
}

/* ===========================================
   タブレット以下のレスポンシブ
   =========================================== */

@media (max-width: 1200px) {
  .form-sections-container {
    flex-direction: column;
  }
  
  .work-info-columns,
  .tool-detail-columns {
    flex-wrap: wrap;
  }
  
  .work-col--hole-type {
    flex: 0 0 150px;
    max-width: 150px;
  }
}

@media (max-width: 900px) {
  .work-info-columns {
    flex-direction: column;
  }
  
  .work-col--hole-type {
    flex: none;
    max-width: 100%;
  }
  
  .hole-type-selector {
    flex-direction: row;
    justify-content: flex-start;
  }
  
  .hole-type-card__img {
    max-width: 80px;
  }
  
  .tool-detail-columns {
    flex-direction: column;
  }
}

/* ===========================================
   Buttons
   =========================================== */

.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: var(--spacing-2) var(--spacing-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.btn--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn--primary:hover:not(:disabled) {
  background-color: var(--color-primary-hover);
}

.btn--primary:disabled {
  background-color: var(--color-gray-300);
  cursor: not-allowed;
}

.btn--secondary {
  background-color: var(--color-secondary-light);
  color: var(--color-secondary);
  border: 1px solid var(--color-gray-300);
}

.btn--secondary:hover:not(:disabled) {
  background-color: var(--color-gray-200);
}

.btn--lang {
  display: flex;
  overflow: hidden;
  padding: 0;
  background-color: rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-sm);
}

.btn--lang .lang-option {
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  transition: all var(--transition-fast);
}

.btn--lang .lang-option.active {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn--lang:hover .lang-option:not(.active) {
  color: rgba(255, 255, 255, 0.9);
}

.btn--unit {
  display: flex;
  overflow: hidden;
  padding: 0;
  background-color: rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-sm);
}

.btn--unit .unit-option {
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  transition: all var(--transition-fast);
}

.btn--unit .unit-option.active {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn--unit:hover .unit-option:not(.active) {
  color: rgba(255, 255, 255, 0.9);
}

.btn--large {
  padding: var(--spacing-3) var(--spacing-6);
  font-size: var(--font-size-base);
}

.btn--small {
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
}

/* ===========================================
   Action Buttons
   =========================================== */

.action-buttons {
  display: flex;
  gap: var(--spacing-3);
  margin-top: var(--spacing-4);
}

.action-buttons .btn {
  flex: 1;
}

/* ===========================================
   Result Area
   =========================================== */

.result-area {
  display: none;
  margin-top: var(--spacing-6);
  padding: var(--spacing-4);
  background-color: var(--color-primary-light);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-primary);
}

.result-area.visible {
  display: block;
}

.result-area__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  margin-bottom: var(--spacing-4);
}

.result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3);
}

.result-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
}

.result-item--full {
  grid-column: 1 / -1;
}

.result-label {
  font-size: var(--font-size-xs);
  color: var(--color-gray-600);
}

.result-value {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-900);
}

.result-unit {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: var(--color-gray-500);
  margin-left: var(--spacing-1);
}

.result-value--model {
  font-family: var(--font-family-mono);
  font-size: var(--font-size-sm);
  padding: var(--spacing-2);
  background-color: var(--color-white);
  border-radius: var(--radius-sm);
}

.result-actions {
  display: flex;
  gap: var(--spacing-3);
  margin-top: var(--spacing-4);
}

.result-actions .btn {
  flex: 1;
}

.result-adjust {
  margin-top: var(--spacing-4);
  padding-top: var(--spacing-4);
  border-top: 1px solid var(--color-gray-300);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
}

.result-adjust__header {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-800);
}

.result-adjust__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--spacing-3);
}

.result-adjust__field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
}

.result-adjust__actions {
  display: flex;
  justify-content: flex-end;
}

.result-adjust__error {
  margin-top: var(--spacing-2);
  padding: var(--spacing-2) var(--spacing-3);
  font-size: var(--font-size-sm);
  color: var(--color-error);
  background-color: rgba(239, 68, 68, 0.1);
  border: 1px solid var(--color-error);
  border-radius: var(--radius-md);
}

/* ===========================================
   Modify Area
   =========================================== */

.modify-area {
  margin-top: var(--spacing-4);
  padding-top: var(--spacing-4);
  border-top: 1px solid var(--color-gray-300);
}

.modify-area__title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-700);
  margin-bottom: var(--spacing-3);
}

.modify-area .form-group {
  margin-bottom: var(--spacing-2);
}

.modify-area .form-label {
  font-size: var(--font-size-xs);
}

.modify-area .form-input {
  padding: var(--spacing-1) var(--spacing-2);
}

.modify-area .btn {
  margin-top: var(--spacing-2);
  width: 100%;
}

/* ===========================================
   Utility Classes
   =========================================== */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ===========================================
   Responsive - Tablet (768px以下)
   =========================================== */

@media (max-width: 768px) {
  :root {
    --sidebar-width: 100%;
  }
  
  html {
    height: auto;
    overflow-y: scroll;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }
  
  body {
    display: block;
    height: auto;
    min-height: auto;
    overflow: visible;
  }
  
  .header {
    flex-wrap: wrap;
    height: auto;
    padding: var(--spacing-3) var(--spacing-4);
    gap: var(--spacing-3);
    position: relative;
    z-index: 100;
  }
  
  .header__brand {
    flex: 1;
    min-width: 0;
  }
  
  .header__logo {
    height: 32px;
  }
  
  .header__title {
    font-size: var(--font-size-base);
  }
  
  .header__subtitle {
    display: none;
  }
  
  .header__controls {
    gap: var(--spacing-2);
  }
  
  .header__version {
    display: none;
  }
  
  .main {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-4);
    overflow: visible;
    height: auto;
    min-height: auto;
    flex: none;
  }
  
  .input-area {
    width: 100%;
    max-width: 100%;
    padding-right: 0;
    max-height: none;
    overflow: visible;
    height: auto;
  }
  
  .preview-area {
    min-height: auto;
    flex: none;
    padding-bottom: var(--spacing-6);
    margin-bottom: var(--spacing-4);
  }
  
  .result-grid {
    grid-template-columns: 1fr;
  }
  
  .action-buttons {
    flex-direction: column;
  }
  
  .action-buttons .btn {
    width: 100%;
  }
  
  /* 4カラムレイアウトのモバイル対応 */
  .form-sections-container {
    flex-direction: column;
    gap: var(--spacing-3);
  }
  
  .work-info-columns,
  .tool-detail-columns {
    flex-direction: column;
    gap: var(--spacing-3);
  }
  
  .work-col,
  .tool-col {
    flex: none;
    max-width: 100%;
    min-width: 0;
  }
  
  .work-col--hole-type {
    max-width: 100%;
  }
  
  .hole-type-selector {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--spacing-2);
  }
  
  .hole-type-option {
    flex: 0 0 auto;
  }
  
  .hole-type-card {
    padding: var(--spacing-2);
  }
  
  .hole-type-card__img {
    max-width: 70px;
  }
  
  .col-header {
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-2);
  }
}

/* モバイルでもフッターを表示 */
@media (max-width: 768px) {
  .footer {
    display: flex;
    padding: var(--spacing-3) var(--spacing-4);
  }
}

/* ===========================================
   Responsive - Mobile (480px以下)
   =========================================== */

@media (max-width: 480px) {
  .header {
    padding: var(--spacing-2) var(--spacing-3);
  }
  
  .header__brand {
    gap: var(--spacing-2);
  }
  
  .header__logo {
    height: 28px;
  }
  
  .header__title {
    font-size: var(--font-size-sm);
  }
  
  .header__title-group {
    gap: 0;
  }
  
  .btn--lang .lang-option,
  .btn--unit .unit-option {
    padding: var(--spacing-1) var(--spacing-1);
    font-size: 10px;
  }
  
  .main {
    padding: var(--spacing-3);
    gap: var(--spacing-4);
    overflow: visible;
    flex: none;
  }
  
  .fieldset {
    padding: var(--spacing-3);
    margin-bottom: var(--spacing-3);
  }
  
  .fieldset__legend {
    font-size: var(--font-size-sm);
  }
  
  .form-group {
    margin-bottom: var(--spacing-3);
  }
  
  .form-radio-group {
    flex-direction: column;
    gap: var(--spacing-2);
  }
  
  .form-input-group {
    flex-wrap: wrap;
  }
  
  .tolerance-group {
    flex-wrap: nowrap;
  }
  
  .form-input--tolerance {
    width: 100px;
  }
  
  .result-area {
    padding: var(--spacing-3);
  }
  
  .result-area__title {
    font-size: var(--font-size-base);
  }
  
  .result-actions {
    flex-direction: column;
  }
  
  .result-actions .btn {
    width: 100%;
  }
  
  .btn--large {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
  }
  
  .footer {
    padding: var(--spacing-2) var(--spacing-3);
    gap: var(--spacing-1);
  }
  
  .footer__nav {
    gap: var(--spacing-3);
  }
  
  .footer__link {
    font-size: var(--font-size-xs);
  }
}
