/* ============================================================================
 * Energianalys AI – v1.8 single column & wider form
 * ============================================================================ */

/* Scope */
.energ-ai-container,
.energ-ai-container * { box-sizing: border-box; }

/* ---------- Shell / layout ---------- */
.energ-ai-container{
  --bg:#fff; --card:#fff; --text:#1f2937; --muted:#6b7280; --line:#e5e7eb;
  --brand1:#667eea; --brand2:#764ba2; --focus:rgba(80,140,255,.25);
  --shadow:0 20px 60px rgba(0,0,0,.18); --radius-lg:20px; --radius-sm:12px;
  --gap:16px;

  /* BREDDA: 1200px och fyll nästan hela vyn */
  width:min(1200px, 96vw);
  margin:20px auto;
  background:var(--card);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  overflow:hidden;
}

/* Header */
.energ-ai-container .energ-ai-header{
  background:linear-gradient(135deg,var(--brand1),var(--brand2));
  color:#fff; padding:32px 36px; text-align:center;
}
.energ-ai-container .energ-ai-header h1{ margin:0; font-size:26px; }
.energ-ai-container .energ-ai-header p{ margin:.35rem 0 0; opacity:.95; }

/* Content */
.energ-ai-container .energ-ai-content{ padding: 32px 36px; }

/* ---------- Form ---------- */
.energ-ai-container .energ-ai-title{
  margin: 26px 0 12px; font-size: 18px; font-weight: 700;
  border-bottom:2px solid var(--line); padding-bottom:8px;
}
.energ-ai-container .energ-ai-form{ display:block; }

.energ-ai-container .energ-ai-form-group{
  display:flex; flex-direction:column; gap:8px; margin-bottom:12px; min-width:0;
}
.energ-ai-container label{ font-size:15px; font-weight:600; color:var(--text); }

/* Inputs – HÖGRE + STÖRRE */
.energ-ai-container .energ-ai-form input[type="text"],
.energ-ai-container .energ-ai-form input[type="email"],
.energ-ai-container .energ-ai-form input[type="number"],
.energ-ai-container .energ-ai-form input:not([type]),
.energ-ai-container .energ-ai-form select,
.energ-ai-container .energ-ai-form textarea{
  width:100%; padding:14px 16px; border:2px solid var(--line);
  border-radius:var(--radius-sm); background:#f8fafc; font-size:16px; line-height:1.45;
  outline:none; transition:border-color .2s, box-shadow .2s, background-color .2s;
  appearance:none; -webkit-appearance:none;
}
.energ-ai-container .energ-ai-form select,
.energ-ai-container .energ-ai-form input[type="text"],
.energ-ai-container .energ-ai-form input[type="email"],
.energ-ai-container .energ-ai-form input[type="number"],
.energ-ai-container .energ-ai-form input:not([type]){ height:54px; }
.energ-ai-container .energ-ai-form textarea{ min-height:140px; resize:vertical; }
.energ-ai-container .energ-ai-form input::placeholder,
.energ-ai-container .energ-ai-form textarea::placeholder{ color:#97a0ad; }

/* Select pil + extra padding */
.energ-ai-container .energ-ai-form select{
  background-image:
    linear-gradient(45deg,transparent 50%, #9ca3af 50%),
    linear-gradient(135deg,#9ca3af 50%, transparent 50%),
    linear-gradient(to right,transparent,transparent);
  background-position:
    calc(100% - 24px) calc(1em + 2px),
    calc(100% - 18px) calc(1em + 2px),
    0 0;
  background-size:6px 6px,6px 6px,2.5em 2.5em;
  background-repeat:no-repeat;
  padding-right:48px;
}

/* Focus */
.energ-ai-container .energ-ai-form input:focus,
.energ-ai-container .energ-ai-form select:focus,
.energ-ai-container .energ-ai-form textarea:focus,
.energ-ai-container .energ-ai-dropzone:focus-within{
  box-shadow:0 0 0 3px var(--focus); border-color:#89aaff; background:#fff;
}

/* Grids i FORM – bredare spacing */
.energ-ai-container .energ-ai-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); }
@media (max-width: 820px){ .energ-ai-container .energ-ai-grid{ grid-template-columns:1fr; } }

.energ-ai-container .energ-ai-3col-grid{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:var(--gap); }
@media (max-width: 1100px){ .energ-ai-container .energ-ai-3col-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width: 820px){  .energ-ai-container .energ-ai-3col-grid{ grid-template-columns:1fr; } }

/* Dropzone */
.energ-ai-container .energ-ai-dropzone{
  border:2px dashed var(--line); background:#f8fafc; border-radius:14px; padding:20px;
  text-align:center; cursor:pointer; transition:transform .08s, box-shadow .2s, background .2s, border-color .2s;
  outline:none; min-height:120px; display:flex; align-items:center; justify-content:center;
}
.energ-ai-container .energ-ai-dropzone:hover,
.energ-ai-container .energ-ai-dropzone.is-hover{ border-color:var(--brand1); background:#f0f4ff; }
.energ-ai-container .energ-ai-dropzone .energ-ai-drop-icon{ font-size:28px; margin-bottom:6px; }
.energ-ai-container .energ-ai-dropzone .energ-ai-drop-link{ text-decoration:underline; color:var(--brand1); }
.energ-ai-container #offers-hint{ text-align:center; color:var(--muted); margin-top:6px; }

/* File tags */
.energ-ai-container .energ-ai-filetags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.energ-ai-container .ea-tag{ display:inline-flex; align-items:center; gap:6px; background:#eef2ff; color:#1f2937; border:1px solid #c7d2fe; border-radius:999px; padding:6px 10px; font-size:13px; }
.energ-ai-container .ea-tag-name{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:320px; }

/* Options grid */
.energ-ai-container .energ-ai-options-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
@media (max-width: 1050px){ .energ-ai-container .energ-ai-options-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 640px){  .energ-ai-container .energ-ai-options-grid{ grid-template-columns:1fr; } }

.energ-ai-container .energ-ai-option{
  display:flex; align-items:center; gap:10px; padding:14px 16px;
  border:2px solid var(--line); border-radius:var(--radius-sm); background:#fff;
  transition:border-color .2s, box-shadow .2s, background .2s; min-height:68px; cursor:pointer;
}
.energ-ai-container .energ-ai-option input[type="checkbox"]{ width:18px; height:18px; accent-color:var(--brand1); }
.energ-ai-container .energ-ai-option:has(input:checked){ border-color:var(--brand1); box-shadow:0 0 0 2px var(--focus); }

/* Submit */
.energ-ai-container .energ-ai-submit{
  width:100%; padding:14px 18px; border:0; border-radius:var(--radius-sm); color:#fff;
  background:linear-gradient(135deg,var(--brand1),var(--brand2)); font-weight:700; font-size:16px;
  cursor:pointer; margin-top:24px; transition:transform .1s, filter .15s;
}
.energ-ai-container .energ-ai-submit:hover{ filter:brightness(1.08); }
.energ-ai-container .energ-ai-submit:active{ transform:translateY(1px) scale(.99); }
.energ-ai-container .energ-ai-submit[disabled]{ opacity:.6; cursor:not-allowed; }

/* Loading */
.energ-ai-container .energ-ai-loading{ margin-top:24px; text-align:center; color:var(--muted); }
.energ-ai-container .energ-ai-spinner{ border:4px solid #f3f3f3; border-top:4px solid var(--brand1); border-radius:50%; width:40px; height:40px; animation:ea-spin 1s linear infinite; margin:0 auto 10px;}
@keyframes ea-spin{ to{ transform:rotate(360deg) } }

/* ---------- Result ---------- */
.energ-ai-container .energ-ai-result{
  margin-top:24px; padding:20px; background:#f8f9fa; border-left:4px solid var(--brand1); border-radius:12px;
}
.energ-ai-container .energ-ai-result pre{ white-space:pre-wrap; line-height:1.6; font-family:inherit; font-size:15px; margin:0; }
.energ-ai-container .energ-ai-result .energ-ai-result-content{ font-size:16px; line-height:1.7; }

/* ---------- REPORT: SINGLE COLUMN ---------- */
.energ-ai-container .energ-ai-report{ display:block !important; }
.energ-ai-container .ear-aside{ margin-bottom:18px; }
.energ-ai-container .ear-card{ background:#fff; border:1px solid #e9eef5; border-radius:12px; padding:16px; box-shadow:0 1px 2px rgba(0,0,0,.04); }
.energ-ai-container .ear-kpi{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width: 720px){ .energ-ai-container .ear-kpi{ grid-template-columns:1fr; } }
.energ-ai-container .ear-kpi .kpi{ border:1px solid #e9eef5; background:#fbfdff; border-radius:10px; padding:12px; }
.energ-ai-container .ear-kpi .kpi h4{ margin:0 0 6px; font-size:13px; color:#444; }
.energ-ai-container .ear-kpi .kpi .v{ font-size:18px; font-weight:700; }

/* Main content typography */
.energ-ai-container .ear-main h1,
.energ-ai-container .ear-main h2,
.energ-ai-container .ear-main h3{ margin-top:18px; }
.energ-ai-container .ear-main a{ color:#0a66c2; text-decoration:none; }
.energ-ai-container .ear-main a:hover{ text-decoration:underline; }

/* Tables – läsbara på mobil med scroll */
.energ-ai-container .ear-main table{
  border-collapse:collapse; width:100%; margin:12px 0; font-size:14px;
  border-radius:10px; overflow:hidden; display:block; max-width:100%; overflow-x:auto;
}
.energ-ai-container .ear-main thead{ display:table; width:100%; table-layout:fixed; }
.energ-ai-container .ear-main tbody{ display:table; width:100%; table-layout:fixed; }
.energ-ai-container .ear-main table th,
.energ-ai-container .ear-main table td{ border:1px solid var(--line); padding:8px 10px; text-align:left; }
.energ-ai-container .ear-main thead th{
  background:linear-gradient(180deg,#f7f9fc,#f2f5fa); font-weight:700;
}
.energ-ai-container .ear-main tbody tr:nth-child(even) td{ background:#fbfdff; }

/* Code */
.energ-ai-container .ear-main code{ background:#fafafa; border:1px solid #eee; padding:0 4px; border-radius:6px; }
.energ-ai-container .ear-main pre{ background:#0b1020; color:#f3f6ff; padding:12px; border-radius:10px; overflow:auto; }

/* Small screen tune */
@media (max-width:560px){
  .energ-ai-container .energ-ai-content{ padding: 22px; }
  .energ-ai-container .energ-ai-header{ padding: 24px; }
  .energ-ai-container .energ-ai-title{ font-size:17px; }
}

/* Visually hidden input (tillgänglig) */
.energ-ai-visually-hidden{
  position:absolute !important; width:1px !important; height:1px !important;
  padding:0 !important; margin:-1px !important; overflow:hidden !important;
  clip:rect(0 0 0 0) !important; white-space:nowrap !important; border:0 !important;
}