/* ============================================================
   Frontek Start — startpage statica, self-contained, zero deps
   Palette brand frontek + tema chiaro/scuro
   ============================================================ */

:root{
  --teal:#2A9D8F; --coral:#E76F51; --dark:#264653; --gold:#E9C46A;
  --green:#8AB17D; --danger:#c0432c;

  /* superfici tema chiaro (default) */
  --bg:#f4f2ea; --bg2:#ece8dc; --card:#ffffff; --line:#e4e0d4;
  --ink:#21333b; --muted:#5a6b73; --faint:#8a979c;
  --shadow:0 1px 2px rgba(38,70,83,.06), 0 6px 20px rgba(38,70,83,.06);
  --accent:var(--teal);
}

/* ---- tema scuro: sistema + override esplicito ---- */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#0f1a1f; --bg2:#132229; --card:#17272e; --line:#24373f;
    --ink:#e8efee; --muted:#9db0b6; --faint:#6f8189;
    --shadow:0 1px 2px rgba(0,0,0,.3), 0 8px 26px rgba(0,0,0,.32);
  }
}
:root[data-theme="dark"]{
  --bg:#0f1a1f; --bg2:#132229; --card:#17272e; --line:#24373f;
  --ink:#e8efee; --muted:#9db0b6; --faint:#6f8189;
  --shadow:0 1px 2px rgba(0,0,0,.3), 0 8px 26px rgba(0,0,0,.32);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; min-height:100vh;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 15% -10%, rgba(42,157,143,.10), transparent 60%),
    radial-gradient(1000px 500px at 100% 0%, rgba(231,111,81,.08), transparent 55%),
    var(--bg);
  display:flex; flex-direction:column;
}
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }

.skip{
  position:absolute; left:-9999px; top:0; background:var(--card); color:var(--ink);
  padding:8px 14px; border-radius:8px; z-index:100;
}
.skip:focus{ left:12px; top:12px; }

/* ---- TOP BAR ---- */
.top{
  display:flex; align-items:center; gap:12px;
  padding:14px clamp(14px,4vw,34px);
}
.top__left, .top__right{ flex:1 1 0; }
.top__right{ display:flex; justify-content:flex-end; }
.top__center{ flex:0 0 auto; }
.brand{
  margin:0; font-size:1.02rem; letter-spacing:.16em; font-weight:800;
  text-transform:uppercase; color:var(--ink);
}
.brand span{ color:var(--coral); }
.clock{ text-align:center; line-height:1.05; }
.clock__time{ display:block; font-size:1.5rem; font-weight:800; letter-spacing:.02em; }
.clock__date{ display:block; font-size:.72rem; color:var(--muted); text-transform:capitalize; }

.iconbtn{
  border:1px solid var(--line); background:var(--card); color:var(--ink);
  width:40px; height:40px; border-radius:11px; font-size:1.15rem; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:transform .12s ease, border-color .12s ease;
}
.iconbtn:hover{ transform:translateY(-1px); border-color:var(--accent); }

/* ---- LAYOUT PRINCIPALE ---- */
.wrap{
  flex:1 1 auto; width:100%; max-width:1120px; margin:0 auto; min-height:0;
  padding:clamp(8px,2.4vw,22px) clamp(14px,4vw,34px) 18px;
  display:flex; flex-direction:column;
}

/* ---- HERO + RICERCA ---- */
.hero{ text-align:center; margin:clamp(12px,4vh,44px) 0 clamp(16px,3.2vh,30px); flex:0 0 auto; }
.greet{
  margin:0 0 18px; font-size:clamp(1.5rem,4.5vw,2.4rem); font-weight:800;
  letter-spacing:-.01em;
}
.search{
  display:flex; align-items:stretch; gap:0; max-width:640px; margin:0 auto;
  background:var(--card); border:1px solid var(--line); border-radius:16px;
  box-shadow:var(--shadow); overflow:hidden;
}
.search:focus-within{ border-color:var(--accent); }
.search__engine{
  border:0; background:transparent; color:var(--muted); padding:0 12px;
  font-size:.86rem; font-weight:600; cursor:pointer; outline:none;
  border-right:1px solid var(--line);
}
.search__input{
  flex:1 1 auto; border:0; background:transparent; color:var(--ink);
  padding:15px 14px; font-size:1.02rem; outline:none; min-width:0;
}
.search__go{
  border:0; background:var(--accent); color:#fff; width:52px; font-size:1.3rem;
  cursor:pointer; transition:filter .12s ease;
}
.search__go:hover{ filter:brightness(1.06); }

/* ---- GRIGLIA WIDGET ----
   Mobile: colonna singola (meteo, segnalibri, titoli).
   Da 640px: meteo come riga a tutta larghezza sopra, poi segnalibri | titoli. */
.grid{
  display:grid; gap:16px; flex:1 1 auto; min-height:0;
  grid-template-columns:1fr;
  align-content:start;
}
@media (min-width:640px){
  .grid{
    grid-template-columns:1fr 1fr;
    grid-template-areas:"wx wx" "links news";
  }
  .card--wx{ grid-area:wx; }
  .card--links{ grid-area:links; }
  .card--news{ grid-area:news; }
  /* meteo orizzontale quando è a tutta larghezza */
  .card--wx .wx{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; overflow:visible; }
  .card--wx .wx__now{ margin-bottom:0; flex:0 0 auto; }
  .card--wx .wx__days{ flex:1 1 340px; max-width:560px; }
}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:16px;
  box-shadow:var(--shadow); padding:16px 18px; min-width:0;
  display:flex; flex-direction:column; min-height:0;
}
.card[hidden]{ display:none; }
.card__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; flex:0 0 auto; }
/* contenuto scrollabile internamente quando la card è vincolata in altezza */
.links, .wx, .news{ flex:1 1 auto; min-height:0; overflow-y:auto; }
.card__title{
  margin:0; font-size:.76rem; font-weight:800; text-transform:uppercase;
  letter-spacing:.1em; color:var(--muted);
}
.linkbtn{
  border:0; background:transparent; color:var(--accent); cursor:pointer;
  font-size:.8rem; font-weight:600; padding:2px 4px;
}
.linkbtn:hover{ text-decoration:underline; }

/* ---- SEGNALIBRI ---- */
.links{ display:grid; grid-template-columns:repeat(auto-fill, minmax(84px,1fr)); gap:8px; }
.tile{
  display:flex; flex-direction:column; align-items:center; gap:7px; text-align:center;
  padding:12px 6px; border-radius:12px; color:var(--ink);
  transition:background .12s ease, transform .12s ease;
}
.tile:hover{ background:var(--bg2); transform:translateY(-1px); text-decoration:none; }
.tile__ic{
  position:relative; overflow:hidden;
  width:38px; height:38px; border-radius:11px; display:flex; align-items:center;
  justify-content:center; font-weight:800; font-size:1.05rem; color:#fff;
}
.tile__fav{
  position:absolute; inset:0; margin:auto; width:24px; height:24px;
  object-fit:contain; display:none;
}
/* quando la favicon reale è caricata: sfondo bianco, nascondi l'iniziale */
.tile__ic.has-fav{ background:#fff !important; color:transparent; }
.tile__ic.has-fav .tile__fav{ display:block; }
.tile__nm{ font-size:.74rem; color:var(--muted); max-width:100%; overflow:hidden;
  text-overflow:ellipsis; white-space:nowrap; }

/* ---- METEO ---- */
.wx__hint, .news__hint{ color:var(--muted); font-size:.9rem; margin:6px 0; }
.wx__now{ display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.wx__emoji{ font-size:2.6rem; line-height:1; }
.wx__temp{ font-size:2rem; font-weight:800; }
.wx__meta{ color:var(--muted); font-size:.86rem; }
.wx__place{ font-weight:700; color:var(--ink); }
.wx__days{ display:flex; gap:6px; }
.wx__day{
  flex:1 1 0; text-align:center; background:var(--bg2); border-radius:10px;
  padding:8px 4px; font-size:.74rem;
}
.wx__day b{ display:block; font-size:.82rem; }
.wx__dico{ font-size:1.15rem; margin:2px 0; }

/* ---- TITOLI ---- */
.news{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.news li + li{ border-top:1px solid var(--line); }
.news a{
  display:block; padding:9px 2px; color:var(--ink); font-size:.92rem; line-height:1.35;
}
.news a:hover{ color:var(--accent); text-decoration:none; }
.news__src{ color:var(--faint); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.04em; }

/* ---- SPONSOR (prima parte, singolo, non invasivo) ---- */
.sponsor{
  display:flex; align-items:center; gap:12px; margin:22px auto 0; max-width:680px;
  background:var(--card); border:1px dashed var(--line); border-radius:14px;
  padding:12px 14px;
}
.sponsor__tag{
  font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em;
  color:var(--faint); border:1px solid var(--line); border-radius:6px; padding:3px 6px;
  flex:0 0 auto;
}
.sponsor__body{ flex:1 1 auto; color:var(--ink); }
.sponsor__body:hover{ text-decoration:none; color:var(--accent); }
.sponsor__text{ font-size:.9rem; }
.sponsor__close{
  border:0; background:transparent; color:var(--faint); font-size:1.2rem; cursor:pointer;
  flex:0 0 auto; line-height:1;
}
.sponsor__close:hover{ color:var(--ink); }

/* ---- FOOTER ---- */
.foot{
  flex:0 0 auto; text-align:center; color:var(--muted); font-size:.74rem;
  padding:10px 16px 14px; display:flex; gap:8px; justify-content:center;
  flex-wrap:wrap; align-items:center;
}
.foot__dot{ color:var(--faint); }

/* ---- MODALI ---- */
.modal{ position:fixed; inset:0; z-index:50; display:flex; align-items:center; justify-content:center; padding:16px; }
.modal[hidden]{ display:none; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(15,26,31,.55); backdrop-filter:blur(2px); }
.modal__box{
  position:relative; background:var(--card); border:1px solid var(--line);
  border-radius:18px; box-shadow:var(--shadow); width:min(520px,100%);
  max-height:88vh; overflow:auto;
}
.modal__head{ display:flex; align-items:center; justify-content:space-between;
  padding:16px 18px; border-bottom:1px solid var(--line); position:sticky; top:0;
  background:var(--card); }
.modal__head h2{ margin:0; font-size:1.06rem; }
.modal__body{ padding:16px 18px; }

.field{ margin-bottom:16px; }
.field--row{ display:flex; gap:10px; }
.field__label{ display:block; font-size:.82rem; font-weight:700; color:var(--muted); margin-bottom:6px; }
.field__hint{ font-size:.75rem; color:var(--faint); margin:6px 0 0; }
.field__select, .field__input, .field__area{
  width:100%; border:1px solid var(--line); background:var(--bg); color:var(--ink);
  border-radius:10px; padding:10px 12px; font-size:.94rem; font-family:inherit; outline:none;
}
.field__select:focus, .field__input:focus, .field__area:focus{ border-color:var(--accent); }
.field__area{ resize:vertical; }
.check{ display:flex; align-items:center; gap:8px; font-size:.92rem; margin:6px 0; cursor:pointer; }
.check input{ accent-color:var(--accent); width:16px; height:16px; }

.btn{
  border:0; background:var(--accent); color:#fff; border-radius:10px; padding:10px 16px;
  font-size:.9rem; font-weight:700; cursor:pointer; transition:filter .12s ease;
}
.btn:hover{ filter:brightness(1.06); }
.btn--light{ background:var(--bg2); color:var(--ink); border:1px solid var(--line); }
.btn--danger{ background:var(--danger); }
.btn--block{ width:100%; margin-top:8px; }

/* editor segnalibri */
.editlist{ list-style:none; margin:0 0 14px; padding:0; }
.editlist li{ display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--line); }
.editlist .en{ font-weight:600; flex:0 0 auto; }
.editlist .eu{ color:var(--muted); font-size:.8rem; flex:1 1 auto; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.editlist .del{ border:0; background:transparent; color:var(--danger); cursor:pointer; font-size:1.1rem; }
.addform{ display:flex; gap:8px; flex-wrap:wrap; }
.addform .field__input{ flex:1 1 120px; width:auto; }

.geolist{ list-style:none; margin:12px 0 0; padding:0; }
.geolist li{ padding:0; }
.geolist button{
  width:100%; text-align:left; border:1px solid var(--line); background:var(--bg);
  color:var(--ink); border-radius:10px; padding:10px 12px; margin-bottom:6px; cursor:pointer;
}
.geolist button:hover{ border-color:var(--accent); }
.geolist small{ color:var(--muted); }

@media (max-width:560px){
  .top__center{ order:3; flex:1 1 100%; margin-top:6px; }
  .clock__time{ font-size:1.25rem; }
}

/* ---- SINGOLA SCHERMATA (desktop con spazio sufficiente) ----
   Tutto entro il viewport, niente scroll di pagina: le card scrollano
   internamente. Su schermi piccoli o bassi si torna al flusso normale. */
@media (min-width:820px) and (min-height:560px){
  html, body{ height:100vh; overflow:hidden; }
  .grid{
    grid-template-rows:auto 1fr;   /* meteo: altezza contenuto; sotto riempie */
    height:100%;
  }
  .hero{ margin-top:clamp(10px,3.2vh,34px); }
}

/* ---- RTL (arabo) ---- */
[dir="rtl"] .search__engine{ border-right:0; border-left:1px solid var(--line); }
[dir="rtl"] .editlist .eu,
[dir="rtl"] .geolist button{ text-align:right; }
