@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

html {
  scroll-behavior: smooth;
}

:root {
  --font-serif: 'Lora', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  
  --font-heading: var(--font-serif);
  --font-body: var(--font-sans);

  /* Colors */
  --bg-app: #fcfbfa; /* Warm off-white */
  --bg-card: #ffffff;
  --text-main: #111111; /* Dark charcoal */
  --text-muted: #555555;
  --text-inverse: #ffffff;
  
  --primary: #111111; /* Charcoal primary color */
  --primary-hover: #2a2a2a;
  --primary-light: #f3f1ed;
  
  /* Yes/Possibly/No color themes matching the mockup */
  --color-yes-bg: #dbe0d4;
  --color-yes-text: #4a5441;
  --color-yes-hover: #cfd6c6;
  
  --color-maybe-bg: #f5e6d8;
  --color-maybe-text: #a06a42;
  --color-maybe-hover: #edd6bf;
  
  --color-no-bg: #f2d8cf;
  --color-no-text: #ab533f;
  --color-no-hover: #e8c4b8;
  
  /* Lighter Neutral States
     Set A (Pronounced version):
     Yes: #e8ede4, Maybe: #faf0e6, No: #f9ebe6
  */
  --color-yes-light: #ebf0e7;
  --color-maybe-light: #fbf3ea;
  --color-no-light: #faf0eb;
  
  /* Logo Colors - 9 Individual Squares (Columns match active selection text colors)
     Column 1 (Yes): #4a5441, Column 2 (Maybe): #a06a42, Column 3 (No): #ab533f
     
     Reference previous values (Original logo colors):
     Green: #7e8d65, Yellow: #ebb96e, Terracotta: #ac3e3d
  */
  /* Row 1 */
  --logo-r1-c1: #4a5441;
  --logo-r1-c2: #a06a42;
  --logo-r1-c3: #ab533f;
  
  /* Row 2 */
  --logo-r2-c1: #4a5441;
  --logo-r2-c2: #a06a42;
  --logo-r2-c3: #ab533f;
  
  /* Row 3 */
  --logo-r3-c1: #4a5441;
  --logo-r3-c2: #a06a42;
  --logo-r3-c3: #ab533f;

  /* Reference Original Values:
     Row 1: #7e8d65, #7e8d65, #e3dfd3
     Row 2: #ebb96e, #ebb96e, #c8beab
     Row 3: #d2ccc0, #f6f3eb, #ac3e3d
  */
  
  --success: #5a684f;
  --success-bg: #dbe0d4;
  --success-border: #cfd6c6;
  --success-text: #4a5441;

  --warning: #a06a42;
  --warning-bg: #f5e6d8;
  --warning-border: #edd6bf;
  --warning-text: #a06a42;

  --danger: #ab533f;
  --danger-bg: #f2d8cf;
  --danger-border: #e8c4b8;
  --danger-text: #ab533f;

  --border-color: #e5e3df; /* Warm grey/tan border */
  --border-hover: #c5c2bd;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.02);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.02);
  --shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.03);
  --radius: 4px;
  --radius-sm: 2px;
  --radius-lg: 6px;
  
  --transition: all 0.15s ease-in-out;
}

/* Reset */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-body);
  background-color: var(--bg-app);
  color: var(--text-main);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  padding: 48px 0; /* vertical padding on body, side margins handled by container */
}

.container {
  max-width: 680px;
  margin: 0 auto;
}

.container-wide {
  max-width: 1440px; /* Centered content max-width */
  margin: 0 auto;
  padding: 0 24px; /* Default mobile padding */
}

@media (min-width: 768px) {
  .container-wide {
    padding: 0 48px; /* Desktop side margin comfortable range start */
  }
}

@media (min-width: 1200px) {
  .container-wide {
    padding: 0 64px; /* Desktop side margin comfortable range end */
  }
}

/* Typography */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--text-main);
  letter-spacing: -0.02em;
}

h1 {
  font-size: 2.2rem;
  line-height: 1.2;
  margin-bottom: 8px;
}

h2 {
  font-size: 1.5rem;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 8px;
}

p {
  color: var(--text-muted);
  margin-bottom: 24px;
}

.subtitle {
  font-size: 1.1rem;
  color: var(--text-muted);
}

/* Navigation / Header */
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
  gap: 16px;
  flex-wrap: wrap;
}

.header-nav-link {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-yes-text);
  text-decoration: none;
  background-color: var(--color-yes-light);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  transition: var(--transition);
}

.header-nav-link:hover {
  background-color: var(--color-yes-bg);
  color: var(--text-main);
}

.header-nav-link .mobile-text {
  display: none;
}

@media (max-width: 580px) {
  header {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }
  .header-nav-link {
    text-align: center;
    white-space: nowrap;
  }
  .header-nav-link .desktop-text {
    display: none;
  }
  .header-nav-link .mobile-text {
    display: inline;
  }
}

@media (max-width: 480px) {
  .container-wide {
    padding: 0 16px;
  }
}

.logo {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--primary);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
}

.logo span {
  background: var(--primary);
  color: var(--text-inverse);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 700;
}

/* Card */
.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-md);
  margin-bottom: 24px;
  transition: var(--transition);
}

.card:hover {
  box-shadow: var(--shadow-lg);
}

.card-subtitle {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #8c8882;
  margin-bottom: 8px;
}


/* Form Elements */
.form-group {
  margin-bottom: 24px;
}

label {
  display: block;
  font-weight: 500;
  margin-bottom: 8px;
  font-size: 0.9rem;
  color: var(--text-main);
}

input[type="text"],
input[type="email"],
input[type="date"],
select {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-main);
  background-color: #fff;
  transition: var(--transition);
  outline: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="date"]:focus,
select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.input-row {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.input-row input {
  flex: 1;
}

/* Time slots container */
.slots-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.slot-item {
  display: flex;
  gap: 12px;
  align-items: center;
  background-color: #fcfcfd;
  padding: 12px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition);
  border: 1px solid transparent;
}

.btn-primary {
  background-color: var(--primary);
  color: var(--text-inverse);
}

.btn-primary:hover {
  background-color: var(--primary-hover);
}

.btn-secondary {
  background-color: #ffffff;
  color: var(--text-main);
  border-color: var(--border-color);
}

.btn-secondary:hover {
  border-color: var(--border-hover);
  background-color: #fbfbfb;
}

.btn-tertiary {
  background-color: #f7f6f3;
  color: var(--text-muted);
  border-color: var(--border-color);
}

.btn-tertiary:hover {
  border-color: var(--border-hover);
  background-color: #e5e2db;
  color: var(--text-main);
}

.btn-danger-outline {
  background-color: #ffffff;
  color: var(--danger);
  border-color: var(--danger-border);
}

.btn-danger-outline:hover {
  background-color: var(--danger-bg);
}

.btn-icon {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 8px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.btn-icon:hover {
  background-color: #f4f4f5;
  color: var(--text-main);
}

.btn-icon.btn-remove {
  color: var(--danger);
}

.btn-icon.btn-remove:hover {
  background-color: var(--danger-bg);
}

.btn-full {
  width: 100%;
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Options / Choices Group */
.choices-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  width: 100%;
}

.choice-option {
  position: relative;
}

.choice-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.choice-label {
  display: block;
  text-align: center;
  padding: 10px 12px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 500;
  font-size: 0.9rem;
  transition: var(--transition);
}

/* Styling for specific choices */
.choice-option.yes input[type="radio"]:checked + .choice-label {
  background-color: var(--success-bg);
  border-color: var(--success-border);
  color: var(--success-text);
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2);
}

.choice-option.maybe input[type="radio"]:checked + .choice-label {
  background-color: var(--warning-bg);
  border-color: var(--warning-border);
  color: var(--warning-text);
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.2);
}

.choice-option.no input[type="radio"]:checked + .choice-label {
  background-color: var(--danger-bg);
  border-color: var(--danger-border);
  color: var(--danger-text);
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.2);
}

.choice-label:hover {
  border-color: var(--border-hover);
}

/* Responses Form Option Row */
.responder-option {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  margin-bottom: 12px;
  background-color: #fff;
}

.responder-option-time {
  font-weight: 600;
  font-size: 0.95rem;
}

/* URL Share Card */
.share-box {
  display: flex;
  gap: 8px;
  margin: 16px 0;
}

.share-url {
  flex: 1;
  font-family: monospace;
  font-size: 0.85rem;
  padding: 10px 12px;
  background-color: #f4f4f5;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  overflow-x: auto;
  white-space: nowrap;
  line-height: 1.4;
}

.share-link {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-color: rgba(85, 85, 85, 0.3);
  white-space: nowrap;
  transition: var(--transition);
}

.share-link:hover {
  color: var(--text-main);
  text-decoration-color: var(--text-main);
}

/* Alert Boxes */
.alert {
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid;
  margin-bottom: 24px;
  font-size: 0.9rem;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.alert-warning {
  background-color: var(--warning-bg);
  border-color: var(--warning-border);
  color: var(--warning-text);
}

.alert-danger {
  background-color: var(--danger-bg);
  border-color: var(--danger-border);
  color: var(--danger-text);
}

.alert-success {
  background-color: var(--success-bg);
  border-color: var(--success-border);
  color: var(--success-text);
}

/* Table Style */
.table-container {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  margin-bottom: 24px;
  background-color: #fff;
}

table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.9rem;
}

th {
  background-color: #f8fafc;
  font-weight: 600;
  color: var(--text-main);
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-color);
  white-space: nowrap;
}

td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-color);
  color: var(--text-muted);
  vertical-align: middle;
}

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

/* Cell values styling */
.badge-choice {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  text-align: center;
}

.badge-choice.y {
  background-color: var(--success-bg);
  color: var(--success-text);
}

.badge-choice.m {
  background-color: var(--warning-bg);
  color: var(--warning-text);
}

.badge-choice.n {
  background-color: var(--danger-bg);
  color: var(--danger-text);
}

/* Summary view */
.summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 360px));
  gap: 24px;
  margin-bottom: 32px;
}

.summary-card {
  background-color: #ffffff;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
  max-width: 360px;
}

.summary-card.best,
.summary-card.joint-best {
  background-color: var(--color-yes-light); /* #ebf0e7 */
  border: 1px solid #dbe0d4; /* subtle green border */
  box-shadow: none;
}

.summary-card.close-second {
  background-color: #f0f3f5; /* soft grey-blue */
  border: 1px solid #d3dae0;
}

.summary-card.alternative {
  background-color: var(--color-maybe-light); /* #fbf3ea */
  border: 1px solid #edd6bf; /* subtle orange-brown border */
}

.summary-card.proposed {
  background-color: #ffffff;
  border: 1px solid var(--border-color);
}

.summary-card.low-support {
  background-color: var(--color-no-light); /* #faf0eb */
  border: 1px solid #e8c4b8; /* subtle terracotta border */
  opacity: 0.85;
}

.summary-card-label {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0px;
}

.summary-card.best .summary-card-label,
.summary-card.joint-best .summary-card-label {
  color: var(--color-yes-text); /* #4a5441 */
}

.summary-card.close-second .summary-card-label {
  color: #4b5d6e;
}

.summary-card.alternative .summary-card-label {
  color: var(--color-maybe-text); /* #a06a42 */
}

.summary-card.low-support .summary-card-label {
  color: var(--color-no-text); /* #ab533f */
}

.summary-card.proposed .summary-card-label {
  color: var(--text-muted);
}

.summary-time {
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 500;
  color: var(--text-main);
  line-height: 1.25;
}

.summary-divider {
  border-top: 1.2px solid var(--border-color);
  margin: 4px 0;
  width: 100%;
}

.summary-stats {
  display: flex;
  gap: 16px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: var(--text-main);
}

.stat-item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.stat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

.stat-dot.y { background-color: var(--color-yes-text); }
.stat-dot.m { background-color: var(--color-maybe-text); }
.stat-dot.n { background-color: var(--color-no-text); }

/* Length counter */
.length-counter {
  margin-top: 8px;
  font-size: 0.8rem;
  text-align: right;
  color: var(--text-muted);
}

.length-counter.warning {
  color: var(--warning-text);
  font-weight: 500;
}

.length-counter.danger {
  color: var(--danger-text);
  font-weight: 600;
}

/* Dashboard Action Bar */
.actions-bar {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
}

.actions-group {
  display: flex;
  gap: 8px;
}

/* Responsive adjustments */
@media (min-width: 480px) {
  .responder-option {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  
  .choices-row {
    width: auto;
    grid-template-columns: repeat(3, 100px);
  }
}

.d-none {
  display: none !important;
}

/* Landing / Hero styles matching mockup */
.hero-grid-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: center;
  margin-bottom: 48px;
  padding-top: 16px;
}

.hero-text-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}

.hero-text-col h1 {
  font-family: var(--font-serif);
  font-size: 5rem;
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: #1d211f;
  margin-bottom: 24px;
}

.hero-subhead {
  font-family: var(--font-sans);
  font-size: 1.2rem;
  line-height: 1.55;
  color: #555555;
  margin-bottom: 32px;
}

.hero-features {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 500;
  color: #555555;
}

.hero-features span {
  display: flex;
  align-items: center;
}

.hero-features span:not(:last-child)::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 14px;
  background-color: #b9b6b0;
  margin-left: 16px;
}

.hero-graphic-col {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
}

.hero-graphic-image {
  width: 100%;
  max-width: 700px;
  height: auto;
  display: block;
  position: relative;
}

/* Steps Grid Card matching mockup */
.steps-grid-card {
  background-color: #ffffff;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  padding: 36px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  margin-bottom: 40px;
}

.step-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}

.steps-grid-card .step-col:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 0;
  bottom: 0;
  width: 1px;
  background-color: var(--border-color);
}

.step-number-accent {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--color-maybe-text);
  line-height: 1;
}

.step-divider-line {
  width: 20px;
  height: 1.5px;
  background-color: var(--color-maybe-text);
  margin-top: 8px;
  margin-bottom: 16px;
}

.step-col h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 12px;
  color: #1d211f;
  letter-spacing: -0.01em;
}

.step-col p {
  font-family: var(--font-sans);
  font-size: 0.88rem;
  line-height: 1.5;
  color: #555555;
  margin-bottom: 0;
}

/* Form Grid & Layout Adjustments */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1.25fr 1fr;
  gap: 24px;
}

.form-actions-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 36px;
  gap: 24px;
}

.form-actions-row .length-counter {
  margin-top: 0;
  text-align: right;
  font-size: 0.85rem;
}

/* Custom Slot Item rows style */
.slot-item {
  display: flex;
  gap: 12px;
  align-items: center;
  background-color: #ffffff;
  padding: 12px 16px;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  animation: fadeIn 0.2s ease-out;
}

.slot-item input[type="date"],
.slot-item select {
  background-color: #fcfbfa !important;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  height: 46px;
  padding: 8px 12px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: var(--text-main);
  outline: none;
  transition: var(--transition);
}

.slot-item input[type="date"]:focus,
.slot-item select:focus {
  border-color: #111111;
  background-color: #ffffff !important;
}

.slot-item .slot-date {
  flex: 1;
}

.slot-item .slot-hour-select,
.slot-item .slot-minute-select {
  width: 90px;
  min-width: 90px;
  text-align: center;
}

.slot-item span {
  font-weight: 600;
  color: var(--text-muted);
}

.slot-item .btn-remove {
  color: var(--danger-text);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.slot-item .btn-remove:hover {
  background-color: var(--danger-bg);
}

/* Hierarchical Date Group styles */
.date-group {
  border: 1.5px solid #d6d3cc;
  border-radius: 6px;
  padding: 16px;
  background-color: #faf9f6;
  margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
  animation: fadeIn 0.25s ease-out;
}

.date-group-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 12px;
  margin-bottom: 12px;
}

.date-group-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
}

.date-group-input {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
  border: none;
  padding: 0;
  margin: 0;
  pointer-events: none;
}

.date-display-label {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-main);
  background-color: #ffffff;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: var(--transition);
}

.date-group-input-wrapper:hover .date-display-label {
  border-color: var(--border-hover);
  background-color: #fcfbfa;
}

.date-group-input-wrapper:focus-within .date-display-label {
  border-color: #111111;
}

.date-group-actions {
  display: flex;
  gap: 8px;
}

.btn-icon.btn-duplicate-group,
.btn-icon.btn-delete-group {
  width: 36px;
  height: 36px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  cursor: pointer;
  color: var(--text-muted);
  transition: var(--transition);
}

.btn-icon.btn-duplicate-group:hover {
  background-color: var(--primary-light);
  color: var(--text-main);
  border-color: var(--border-hover);
}

.btn-icon.btn-delete-group:hover {
  background-color: var(--danger-bg);
  color: var(--danger-text);
  border-color: var(--danger-border);
}

/* Nested Time Slots */
.time-slots-container {
  padding-top: 4px;
}

.time-slots-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.time-slot-item {
  display: inline-flex;
  align-items: center;
  background-color: #ffffff;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  padding: 4px 6px 4px 10px;
  height: 42px;
  animation: fadeIn 0.2s ease-out;
  transition: var(--transition);
}

.time-slot-item:focus-within {
  border-color: #111111;
}

.time-slot-item .slot-time-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: transparent !important;
  border: none;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-main);
  outline: none;
  height: auto;
  cursor: pointer;
  width: 115px;
  padding: 0;
  margin: 0;
  text-align: center;
  text-align-last: center;
}

.time-slot-item .slot-time-select option {
  text-align: left;
  text-align-last: left;
  padding: 4px 8px;
}

.btn-delete-time {
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  height: 22px;
  width: auto;
  border-radius: 4px;
  margin-left: 4px;
  transition: var(--transition);
}

.btn-delete-time:hover {
  background-color: var(--danger-bg);
  color: var(--danger-text);
}

/* Unified dashed interval buttons group */
.time-slot-buttons-group {
  display: inline-flex;
  border: 1px dashed var(--border-color);
  border-radius: 4px;
  overflow: hidden;
  height: 42px;
  transition: var(--transition);
}

.time-slot-buttons-group:hover {
  border-color: var(--border-hover);
}

.btn-add-time-interval {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  border: none;
  padding: 0 12px;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: var(--transition);
}

.btn-add-time-interval:not(:last-child) {
  border-right: 1px dashed var(--border-color);
}

.btn-add-time-interval:hover {
  background-color: var(--primary-light);
  color: var(--text-main);
}

@media (max-width: 768px) {
  .hero-grid-container {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 24px;
  }
  
  .hero-text-col {
    align-items: center;
    text-align: center;
  }
  
  .hero-text-col h1 {
    font-size: 2.6rem;
  }
  
  .hero-features {
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
  }
  
  .hero-features span:not(:last-child)::after {
    display: none;
  }
  
  .hero-graphic-col {
    justify-content: center;
  }
  
  .hero-graphic-image {
    left: 0;
    max-width: 100%;
  }

  .steps-grid-card {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 24px;
  }
  
  .steps-grid-card .step-col:not(:last-child)::after {
    display: none;
  }
  
  .step-col {
    align-items: center;
    text-align: center;
  }
  
  .step-divider-line {
    margin-left: auto;
    margin-right: auto;
  }

  .form-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .form-actions-row {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }
  
  .form-actions-row .length-counter {
    text-align: center;
  }

  .slot-item {
    flex-wrap: wrap;
    gap: 8px;
  }

  .slot-item .slot-date {
    flex: 1 1 100%;
  }

  .slot-item .slot-hour-select,
  .slot-item .slot-minute-select {
    flex: 1;
    min-width: 70px;
  }
}

/* ==========================================================================
   WHEN FREE NEW EDITORIAL UI DESIGN STYLES
   ========================================================================== */

/* Header Styles */
.app-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 24px;
  margin-bottom: 40px;
  border-bottom: 1.5px solid #111111;
  width: 100%;
}

@media (max-width: 600px) {
  .app-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
  }
}

.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--text-main);
  background: transparent !important;
  padding: 0 !important;
}

.logo svg g rect {
  opacity: 0.4;
}

/*
  Original 3x3 Logo Grid Colors:
  Row 1: [Col 1: #7e8d65 (Sage Green)]  [Col 2: #7e8d65 (Sage Green)]  [Col 3: #e3dfd3 (Light Cream)]
  Row 2: [Col 1: #ebb96e (Warm Yellow)] [Col 2: #ebb96e (Warm Yellow)] [Col 3: #c8beab (Medium Grey)]
  Row 3: [Col 1: #d2ccc0 (Light Grey)]  [Col 2: #f6f3eb (Off-White)]   [Col 3: #ac3e3d (Terracotta)]
*/
.logo-grid {
  display: grid;
  grid-template-columns: repeat(3, 6px);
  grid-template-rows: repeat(3, 6px);
  gap: 2.5px;
  margin-top: 2px;
}

.logo-grid .dot {
  width: 6px;
  height: 6px;
  border-radius: 0.5px;
}

/* Individual square mapping for logo grid */
.logo-grid .d1 { background-color: var(--logo-r1-c1); }
.logo-grid .d2 { background-color: var(--logo-r1-c2); }
.logo-grid .d3 { background-color: var(--logo-r1-c3); }
.logo-grid .d4 { background-color: var(--logo-r2-c1); }
.logo-grid .d5 { background-color: var(--logo-r2-c2); }
.logo-grid .d6 { background-color: var(--logo-r2-c3); }
.logo-grid .d7 { background-color: var(--logo-r3-c1); }
.logo-grid .d8 { background-color: var(--logo-r3-c2); }
.logo-grid .d9 { background-color: var(--logo-r3-c3); }

.logo-text {
  font-family: var(--font-serif);
  font-size: 1.85rem;
  font-weight: 500;
  color: #1d211f;
  letter-spacing: -0.025em;
  line-height: 1;
}

.header-note {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.95rem;
  color: #1d211f;
  text-align: right;
  line-height: 1.45;
}

@media (max-width: 600px) {
  .header-note {
    text-align: center;
  }
}

/* Hero Title section */
.poll-hero {
  margin-top: 48px;
  margin-bottom: 0;
}

.poll-hero h1 {
  font-family: var(--font-serif);
  font-size: 3.5rem;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: #1d211f;
  margin-bottom: 6px; /* Reduced margin to bring organiser tag closer */
  line-height: 1.15;
}

.organiser-tag {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: #555555;
  margin-bottom: 24px;
}

.organiser-tag strong, .organiser-tag span, .organiser-tag a {
  color: #555555;
}

.organiser-tag a {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(85, 85, 85, 0.4);
  transition: all 0.15s ease-in-out;
}

.organiser-tag a:hover {
  color: var(--color-maybe-text);
  text-decoration-color: var(--color-maybe-text);
}

.availability-prompt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.1rem;
  color: #555555;
  margin-top: 28px; /* Reduced margin to bring closer to organiser tag */
  margin-bottom: 20px;
}

/* Availability Grid/Table Styles */
.table-wrapper {
  width: 100%;
  overflow-x: auto;
  margin-bottom: 40px;
}

.availability-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
}

.availability-table th {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: #1d211f;
  border-bottom: 1.2px solid var(--border-color);
  padding: 16px 8px;
  background-color: transparent !important; /* Remove blue background */
}

.availability-table td {
  padding: 8px 8px; /* Balanced padding for a clearly visible gap */
  border-bottom: 1.2px solid var(--border-color);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: #1d211f;
  vertical-align: middle;
}

/* Yes/Maybe/No choice buttons inside Table */
.choice-cell {
  width: 180px;
  text-align: center;
  font-size: 0 !important;
  line-height: 0 !important;
  padding: 8px 8px !important;
}

.choice-btn-wrapper {
  position: relative;
  display: block; /* block display removes all baseline alignment shifts and whitespace gaps */
  margin: 0 auto;
  width: 100%;
  max-width: 170px;
}

.choice-btn-wrapper input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.choice-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px; /* Tighter button block height */
  margin: 0;
  padding: 0;
  border-radius: 2px;
  font-family: var(--font-sans);
  font-size: 0.95rem; /* Resets text size inside button context */
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease-in-out;
  background-color: transparent;
  user-select: none;
}

/* Column specific active and inactive styling */

/* Neutral state: when no option in the row is selected, show light colors */
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.yes .choice-btn {
  background-color: var(--color-yes-light);
  color: var(--color-yes-text);
}
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.maybe .choice-btn {
  background-color: var(--color-maybe-light);
  color: var(--color-maybe-text);
}
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.no .choice-btn {
  background-color: var(--color-no-light);
  color: var(--color-no-text);
}

/* Hover state when no option is selected (reveal full dark colors) */
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.yes .choice-btn:hover {
  background-color: var(--color-yes-bg);
  color: var(--color-yes-text);
  font-weight: 600;
}
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.maybe .choice-btn:hover {
  background-color: var(--color-maybe-bg);
  color: var(--color-maybe-text);
  font-weight: 600;
}
tr:not(:has(input[type="radio"]:checked)) .choice-btn-wrapper.no .choice-btn:hover {
  background-color: var(--color-no-bg);
  color: var(--color-no-text);
  font-weight: 600;
}

/* When a selection exists in the row, make unselected buttons transparent */
tr:has(input[type="radio"]:checked) .choice-btn-wrapper .choice-btn {
  background-color: transparent;
  color: var(--text-muted);
}

/* Checked states (override the transparent state instantly) */
.choice-btn-wrapper.yes input[type="radio"]:checked + .choice-btn {
  background-color: var(--color-yes-bg) !important;
  color: var(--color-yes-text) !important;
  font-weight: 600;
}
.choice-btn-wrapper.maybe input[type="radio"]:checked + .choice-btn {
  background-color: var(--color-maybe-bg) !important;
  color: var(--color-maybe-text) !important;
  font-weight: 600;
}
.choice-btn-wrapper.no input[type="radio"]:checked + .choice-btn {
  background-color: var(--color-no-bg) !important;
  color: var(--color-no-text) !important;
  font-weight: 600;
}

/* Hover states for unselected buttons when row has a selection (reveal light colors) */
tr:has(input[type="radio"]:checked) .choice-btn-wrapper.yes input[type="radio"]:not(:checked) + .choice-btn:hover {
  background-color: var(--color-yes-light);
  color: var(--color-yes-text);
}
tr:has(input[type="radio"]:checked) .choice-btn-wrapper.maybe input[type="radio"]:not(:checked) + .choice-btn:hover {
  background-color: var(--color-maybe-light);
  color: var(--color-maybe-text);
}
tr:has(input[type="radio"]:checked) .choice-btn-wrapper.no input[type="radio"]:not(:checked) + .choice-btn:hover {
  background-color: var(--color-no-light);
  color: var(--color-no-text);
}

/* Name/Email/Submit row */
.response-submit-row {
  display: grid;
  grid-template-columns: 1.2fr 1.5fr auto;
  gap: 24px;
  align-items: flex-start;
  margin-top: 48px;
  margin-bottom: 48px;
}

.response-submit-row .form-group {
  margin-bottom: 0;
}

.response-submit-row label {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 600;
  color: #1d211f;
  margin-bottom: 8px;
  display: block;
  line-height: 1.4;
}

.response-submit-row label .required {
  color: var(--color-no-text);
}

.response-submit-row label em {
  font-style: italic;
  font-weight: 400;
  color: var(--text-muted);
}

.response-submit-row input[type="text"],
.response-submit-row input[type="email"] {
  width: 100%;
  height: 54px; /* Same height as button */
  padding: 12px 16px;
  background-color: #fcfbfa; /* Warm off-white input */
  border: 1px solid #999999;
  border-radius: 4px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: #1d211f;
  transition: all 0.15s ease-in-out;
  outline: none;
}

.response-submit-row input[type="text"]:focus,
.response-submit-row input[type="email"]:focus {
  border-color: #111111;
  background-color: #ffffff;
}

.form-helper {
  display: block;
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 6px;
}

.submit-group {
  padding-top: calc(0.85rem * 1.4 + 8px); /* Align button top with input top perfectly */
  display: flex;
  justify-content: flex-end; /* Align button to the far right */
}

.btn-submit-black {
  display: flex;
  align-items: center;
  justify-content: center; /* Center text and icon horizontally inside the button */
  gap: 12px;
  width: 270px; /* Wider and more spacious */
  max-width: 100%;
  height: 54px; /* Increased height */
  padding: 0 24px;
  background-color: #1d211f;
  color: #ffffff;
  border: none;
  border-radius: 4px;
  font-family: var(--font-serif); /* Serif font matching mock exactly */
  font-size: 1.05rem;
  font-weight: 400;
  cursor: pointer;
  transition: background-color 0.15s ease-in-out;
}

.btn-submit-black:hover {
  background-color: #2e3330;
}

.btn-submit-black .arrow-icon {
  transition: transform 0.15s ease-in-out;
}

.btn-submit-black:hover .arrow-icon {
  transform: translateX(4px);
}

/* Footer Section */
.app-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-top: 24px;
  margin-top: 60px;
  border-top: 1.5px solid #111111;
  font-family: var(--font-serif);
}

.footer-credits {
  font-size: 0.95rem;
  color: var(--text-muted);
  text-align: right;
  line-height: 1.45;
}

.footer-link {
  color: var(--text-main);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(17, 17, 17, 0.3);
  font-weight: 500;
  transition: all 0.15s ease-in-out;
}

.footer-link:hover {
  color: var(--color-maybe-text);
  text-decoration-color: var(--color-maybe-text);
}

/* Creator page overrides for editorial styling */
.creator-hero h1 {
  font-family: var(--font-serif);
  font-size: 3.2rem;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--text-main);
  margin-bottom: 12px;
}

.creator-tagline {
  font-size: 1.15rem;
  color: var(--text-muted);
  max-width: 650px;
  margin: 12px auto 0;
}

.step-card {
  border-radius: 4px;
  border-color: var(--border-color);
  background-color: #fcfbfa;
}

.step-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 600;
}

.card {
  border-radius: 4px;
  border-color: var(--border-color);
  background-color: #ffffff;
  box-shadow: none;
}

.card:hover {
  box-shadow: none;
}

/* Custom styles for select and date slots on Creator */
.slot-item {
  border-radius: 4px;
  border-color: var(--border-color);
}

.btn-primary {
  background-color: #111111;
  color: #ffffff;
  border-radius: 4px;
}

.btn-primary:hover {
  background-color: #2a2a2a;
}

.badge-organiser {
  color: var(--text-muted);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
}

#active-poll-view .table-container {
  border: none;
  background-color: transparent;
  border-radius: 0;
  margin-bottom: 32px;
  box-shadow: none;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

#responses-table {
  width: 100%;
  border-collapse: collapse;
}

#responses-table th {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: #1d211f;
  border-bottom: 1.2px solid var(--border-color);
  padding: 16px 16px;
  background-color: transparent !important;
}

#responses-table td {
  padding: 16px 16px;
  border-bottom: 1.2px solid var(--border-color);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: var(--text-main);
  vertical-align: middle;
}

#responses-table tr:last-child td {
  border-bottom: none;
}

#responses-table th:nth-child(1),
#responses-table td:nth-child(1) {
  text-align: left;
}

#responses-table th:nth-child(n+2),
#responses-table td:nth-child(n+2) {
  text-align: center;
}

/* Give slots columns a consistent width so they don't stretch excessively on wide screens */
#responses-table th:nth-child(n+2):not(:last-child),
#responses-table td:nth-child(n+2):not(:last-child) {
  width: 180px;
  min-width: 150px;
}

#responses-table th:last-child,
#responses-table td:last-child {
  width: 90px;
}

#responses-table td a {
  color: #1d211f;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(17, 17, 17, 0.4);
  transition: all 0.15s ease-in-out;
}

#responses-table td a:hover {
  color: var(--color-maybe-text);
  text-decoration-color: var(--color-maybe-text);
}

#responses-table .btn-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: 4px;
  color: var(--danger-text);
  transition: var(--transition);
}

#responses-table .btn-remove:hover {
  background-color: var(--danger-bg);
}

#responses-table .badge-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 36px;
  border-radius: 2px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 500;
  text-align: center;
  padding: 0;
}

#responses-table .badge-choice.y {
  background-color: var(--color-yes-bg) !important;
  color: var(--color-yes-text) !important;
}

#responses-table .badge-choice.m {
  background-color: var(--color-maybe-bg) !important;
  color: var(--color-maybe-text) !important;
}

#responses-table .badge-choice.n {
  background-color: var(--color-no-bg) !important;
  color: var(--color-no-text) !important;
}

.actions-bar .btn {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.88rem;
  padding: 8px 16px;
  border-radius: 4px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  body {
    padding: 24px 16px;
  }
  
  .poll-hero h1, .creator-hero h1 {
    font-size: 2.2rem;
  }
  
  .response-submit-row {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .submit-group {
    padding-top: 0;
    justify-content: center;
  }
  
  .app-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  
  .header-note {
    text-align: left;
  }
}

/* ==========================================================================
   QR SCANNER MODAL & VIEWPORT STYLES
   ========================================================================== */
.scanner-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(252, 251, 250, 0.94); /* Warm off-white backdrop */
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1100;
  padding: 20px;
  animation: modalFadeIn 0.2s ease-out;
}

@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.scanner-content {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 28px;
  width: 100%;
  max-width: 480px;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-sizing: border-box;
  transition: border-color 0.2s, box-shadow 0.2s;
  animation: cardSlideUp 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes cardSlideUp {
  from { opacity: 0; transform: translateY(15px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Flash notifications */
.scanner-content.flash-success {
  box-shadow: 0 0 0 6px rgba(90, 104, 79, 0.15), var(--shadow-lg);
  border-color: var(--success-border);
}

.scanner-content.flash-error {
  box-shadow: 0 0 0 6px rgba(171, 83, 63, 0.15), var(--shadow-lg);
  border-color: var(--danger-border);
}

.scanner-header h2 {
  font-size: 1.4rem;
  font-family: var(--font-heading);
  color: var(--text-main);
}

.scanner-view-container {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  background-color: #f7f5f0;
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

#qr-reader {
  width: 100% !important;
  height: 100% !important;
}

#qr-reader video {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
}

/* Reticle guides on top of video feed */
.scanner-target-reticle {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 2;
  animation: reticle-pulse 2.2s infinite ease-in-out;
}

@keyframes reticle-pulse {
  0% { opacity: 0.55; transform: translate(-50%, -50%) scale(0.98); }
  50% { opacity: 1; transform: translate(-50%, -50%) scale(1.02); }
  100% { opacity: 0.55; transform: translate(-50%, -50%) scale(0.98); }
}

.reticle-corner {
  position: absolute;
  width: 24px;
  height: 24px;
  border: 3.5px solid var(--primary); /* clean charcoal guides */
}

.reticle-corner.tl { top: 0; left: 0; border-right: none; border-bottom: none; }
.reticle-corner.tr { top: 0; right: 0; border-left: none; border-bottom: none; }
.reticle-corner.bl { bottom: 0; left: 0; border-right: none; border-top: none; }
.reticle-corner.br { bottom: 0; right: 0; border-left: none; border-top: none; }

/* Status alerts */
#scan-status-indicator {
  padding: 10px 14px;
  border-radius: var(--radius);
  font-size: 0.85rem;
  font-weight: 500;
  text-align: center;
  transition: var(--transition);
  margin-bottom: 12px;
  line-height: 1.4;
}

.scan-status-idle {
  background-color: var(--primary-light);
  color: var(--text-muted);
  border: 1px solid var(--border-color);
}

.scan-status-ready {
  background-color: var(--primary-light);
  color: var(--text-main);
  border: 1px solid var(--border-color);
}

.scan-status-success {
  background-color: var(--success-bg);
  color: var(--success-text);
  border: 1px solid var(--success-border);
  font-weight: 600;
}

.scan-status-error {
  background-color: var(--danger-bg);
  color: var(--danger-text);
  border: 1px solid var(--danger-border);
}

/* Scanned History List container */
.scan-log-container {
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  padding: 12px;
  background-color: #fbfbf9;
  max-height: 130px;
  overflow-y: auto;
}

.scan-session-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.session-log-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.82rem;
  padding: 4px 6px;
  border-radius: var(--radius-sm);
  transition: background-color 0.25s;
  animation: slideInLog 0.22s ease-out;
}

@keyframes slideInLog {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.log-indicator {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 10px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
  text-align: center;
}

.log-indicator.new {
  background-color: var(--success-bg);
  color: var(--success-text);
}

.log-indicator.update {
  background-color: var(--warning-bg);
  color: var(--warning-text);
}

.log-details {
  display: flex;
  flex-direction: column;
  line-height: 1.35;
}

.log-name {
  font-weight: 600;
  color: var(--text-main);
}

.log-email {
  font-size: 0.72rem;
  color: var(--text-muted);
}

.empty-log-item {
  font-size: 0.8rem;
  color: var(--text-muted);
  text-align: center;
  padding: 8px 0;
  font-style: italic;
}

/* Pulsing highlight if record gets rescanned */
@keyframes updated-flash {
  0% { background-color: var(--warning-bg); }
  100% { background-color: transparent; }
}

.updated-pulse {
  animation: updated-flash 0.9s ease-out;
}

/* Hide Scan Responses button on desktop screens */
@media (min-width: 601px) {
  #btn-scan-qr {
    display: none !important;
  }
}

/* Responsive overrides for results action buttons on mobile screens */
@media (max-width: 600px) {
  #btn-mobile-sync,
  #btn-export-csv {
    display: none !important;
  }
  
  /* Actions bar and buttons alignment on mobile */
  .actions-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  
  .actions-group {
    width: 100%;
  }
  
  .actions-group .btn {
    flex: 1;
  }
  
  #btn-clear-all {
    width: 100%;
  }
  
  /* Scanner modal breathing room and layout adjustments on mobile */
  .scanner-modal {
    display: block;
    overflow-y: auto;
    padding: 16px;
  }
  
  .scanner-content {
    margin: 16px auto;
    padding: 20px;
    gap: 16px;
  }
  
  .scanner-header h2 {
    font-size: 1.25rem;
  }
  
  #scan-status-indicator {
    padding: 8px 12px;
    font-size: 0.8rem;
    margin-bottom: 8px;
  }
  
  .scan-log-container {
    padding: 8px;
    max-height: 100px;
  }
}

/* Responsive table scroll helper for tablets and mobile */
@media (max-width: 768px) {
  .table-scroll-helper {
    display: inline-flex !important;
  }
}

