/* static/style.css */
/* Senior-first: sehr große Schriften, hoher Kontrast, wenig Ablenkung */

/* =========================
   LIGHT THEME VARIABLES
   ========================= */
   :root{
    /* Hintergrund: leicht warm, nicht grell */
    --bg: #f6f7fb;
  
    /* Panels: weiß, aber minimal abgesetzt */
    --panel: #ffffff;
  
    /* Text: sehr dunkel */
    --text: #111318;
  
    /* Sekundärtexte */
    --muted: #4b5565;
    --muted2: #6b7280;
  
    /* Akzente (beibehalten, aber auf hell gut lesbar) */
    --accent: #caa400;   /* etwas dunkleres Gelb -> besser auf Weiß */
    --accent2: #007c91;  /* dunkleres Cyan -> besser auf Weiß */
  
    /* Status */
    --danger: #cc1f2a;
    --ok: #118a52;
  
    /* Schatten + Border: heller und subtil */
    --shadow: rgba(17, 19, 24, 0.12);
    --border: rgba(17, 19, 24, 0.15);
  }
  
  * { box-sizing: border-box; }
  
  html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  
  a { color: inherit; text-decoration: none; }
  a:focus, button:focus, input:focus, select:focus {
    outline: 4px solid rgba(0,124,145,0.75); /* --accent2 */
    outline-offset: 2px;
  }
  
  /* TOPBAR */
  .topbar{
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 2px solid var(--border);
    background: #ffffff;
    box-shadow: 0 4px 18px var(--shadow);
  }
  
  .clockblock{
    min-width: 220px;
  }
  
  .clock{
    font-size: 58px; /* wichtig: sehr groß */
    font-weight: 800;
    letter-spacing: 1px;
    line-height: 1;
  }
  
  .date{
    margin-top: 4px;
    font-size: 22px;
    color: var(--muted);
    font-weight: 700;
  }
  
  .stand{
    margin-top: 6px;
    font-size: 14px;
    color: var(--muted2);
  }
  
  /* MENU */
  .menu{
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .menubtn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
  
    padding: 16px 18px;
    min-width: 165px;
    border-radius: 14px;
  
    font-size: 22px;
    font-weight: 800;
  
    background: var(--panel);
    border: 2px solid var(--border);
    box-shadow: 0 6px 16px var(--shadow);
  }
  
  .menubtn.active{
    border-color: rgba(202,164,0,0.9); /* --accent */
    box-shadow: 0 0 0 4px rgba(202,164,0,0.20), 0 6px 16px var(--shadow);
  }
  
  .adminlink{
    display: flex;
    justify-content: flex-end;
  }
  
  .adminbtn{
    font-size: 18px;
    font-weight: 800;
    padding: 12px 16px;
    border-radius: 12px;
    background: transparent;
    border: 2px solid var(--border);
  }
  
  /* CONTENT */
  .content{
    padding: 16px;
    max-width: 1080px;
    margin: 0 auto;
  }
  
  .headline h1{
    font-size: 38px;
    margin: 8px 0 4px;
    font-weight: 900;
  }
  
  .subline{
    font-size: 18px;
    color: var(--muted);
    font-weight: 700;
  }
  
  /* EMPTY */
  .empty{
    background: var(--panel);
    border: 2px solid var(--border);
    border-radius: 16px;
    padding: 22px;
    margin-top: 16px;
    box-shadow: 0 8px 18px var(--shadow);
  }
  .emptybig{ font-size: 28px; font-weight: 900; }
  .emptysmall{ font-size: 18px; color: var(--muted); margin-top: 6px; }
  
  /* CARDS */
  .cards{
    margin-top: 16px;
    display: grid;
    gap: 16px;
  }
  
  .card{
    background: var(--panel);
    border: 2px solid var(--border);
    border-radius: 18px;
    padding: 18px;
    box-shadow: 0 10px 22px var(--shadow);
    overflow: hidden;
  }
  
  .cardtop{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 14px;
    align-items: start;
  }
  
  .meta{
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  
  .source{
    font-size: 20px;
    font-weight: 900;
    color: var(--accent2);
  }
  
  .datebadge{
    display: inline-block;
    font-size: 16px;
    font-weight: 800;
    color: var(--muted);
    border: 2px solid var(--border);
    padding: 8px 10px;
    border-radius: 12px;
    width: fit-content;
    background: rgba(17,19,24,0.03);
  }
  
  .imgwrap{
    width: 160px;
    max-width: 160px;
    border-radius: 14px;
    overflow: hidden;
    border: 2px solid var(--border);
    background: #f2f4f8;
  }
  
  .imgwrap img{
    display: block;
    width: 100%;
    height: auto;
  }
  
  /* TITLE + SUMMARY */
  .title{
    font-size: 28px;
    margin: 14px 0 10px;
    font-weight: 950;
  }
  
  .summary{
    font-size: 22px;
    line-height: 1.35;
    color: var(--text);
    margin: 0 0 14px;
  }
  
  .summary .tts-word{
    padding: 2px 4px;
    border-radius: 8px;
  }
  
  .summary .tts-word.active{
    background: rgba(202,164,0,0.28);
    box-shadow: 0 0 0 3px rgba(202,164,0,0.18);
  }
  
  /* ACTIONS */
  .actions{
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }
  
  .btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  
    padding: 16px 18px;
    border-radius: 16px;
  
    font-size: 22px;
    font-weight: 900;
  
    background: #f2f4f8;
    color: var(--text);
    border: 2px solid var(--border);
    box-shadow: 0 6px 14px var(--shadow);
  }
  
  .btn.big{
    font-size: 24px;
    padding: 18px 20px;
    border-radius: 18px;
  }
  
  .btn.speak{
    background: rgba(0,124,145,0.12);
    border-color: rgba(0,124,145,0.35);
  }
  
  .btn.open{
    background: rgba(202,164,0,0.12);
    border-color: rgba(202,164,0,0.35);
  }
  
  .btn.secondary{
    background: transparent;
    box-shadow: none;
  }
  
  .btn.danger{
    background: rgba(204,31,42,0.10);
    border-color: rgba(204,31,42,0.40);
  }
  
  /* FLASH */
  .flashwrap{ margin: 12px 0; display: grid; gap: 10px; }
  .flash{
    border-radius: 14px;
    padding: 14px 16px;
    border: 2px solid var(--border);
    font-size: 18px;
    font-weight: 800;
    background: var(--panel);
  }
  .flash.success{ border-color: rgba(17,138,82,0.45); background: rgba(17,138,82,0.10); }
  .flash.error{ border-color: rgba(204,31,42,0.50); background: rgba(204,31,42,0.10); }
  
  /* ADMIN */
  .admin-body{
    background: var(--bg);
    padding: 18px;
  }
  .admin, .admin-login{
    max-width: 900px;
    margin: 0 auto;
  }
  .adminhead{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
  }
  .adminhead h1{ font-size: 34px; margin: 0; }
  .adminhead-actions{ display: flex; gap: 10px; flex-wrap: wrap; }
  
  .admincard{
    margin-top: 16px;
    padding: 18px;
    border-radius: 18px;
    border: 2px solid var(--border);
    background: var(--panel);
    box-shadow: 0 10px 22px var(--shadow);
  }
  .admincard h2{ margin: 0 0 12px; font-size: 24px; }
  
  .adminform{
    display: grid;
    gap: 10px;
  }
  .adminform label{
    font-size: 18px;
    font-weight: 800;
    color: var(--muted);
  }
  .adminform input, .adminform select, .pininput{
    font-size: 20px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 2px solid var(--border);
    background: #ffffff;
    color: var(--text);
    box-shadow: 0 6px 14px var(--shadow);
  }
  .checkrow{
    display: flex;
    gap: 12px;
    align-items: center;
    font-size: 20px;
    font-weight: 800;
    color: var(--text);
  }
  .checkrow input{
    width: 26px;
    height: 26px;
  }
  
  .sourcelist{
    display: grid;
    gap: 12px;
  }
  .sourceitem{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    border: 2px solid var(--border);
    background: #ffffff;
    box-shadow: 0 8px 18px var(--shadow);
  }
  .sname{ font-size: 22px; font-weight: 950; }
  .surl{ font-size: 16px; color: var(--muted); word-break: break-all; margin-top: 4px; }
  .scat, .senabled{ font-size: 16px; color: var(--muted2); margin-top: 6px; font-weight: 700; }
  .on{ color: var(--ok); font-weight: 900; }
  .off{ color: var(--danger); font-weight: 900; }
  
  .sactions{
    display: grid;
    gap: 10px;
    align-content: start;
  }
  
  /* ADMIN LOGIN */
  .admin-login h1{ font-size: 40px; margin: 10px 0; }
  .adminhint{ font-size: 18px; color: var(--muted); font-weight: 700; }
  .pinform{ display: grid; gap: 12px; margin-top: 12px; max-width: 420px; }
  .pinform label{ font-size: 18px; font-weight: 900; color: var(--muted); }
  .pininput{ font-size: 28px; letter-spacing: 8px; text-align: center; padding: 16px; }
  
  /* KIOSK MODE */
  body.kiosk .topbar{
    grid-template-columns: auto 1fr;
    align-items: start;
  }
  
  body.kiosk .content{
    max-width: 1200px;
  }
  
  body.kiosk .clock{
    font-size: 72px;
  }
  
  body.kiosk .date{
    font-size: 26px;
  }
  
  body.kiosk .menubtn{
    font-size: 28px;
    padding: 20px 22px;
    min-width: 200px;
  }
  
  body.kiosk .title{
    font-size: 32px;
  }
  
  body.kiosk .summary{
    font-size: 24px;
  }
  
  body.kiosk .btn{
    font-size: 26px;
    padding: 18px 20px;
  }
  
  .kiosk-actions{
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
  }
  
  .actionbtn{
    cursor: pointer;
    padding: 16px 18px;
    border-radius: 16px;
    border: 2px solid var(--border);
    background: #ffffff;
    color: var(--text);
    font-size: 22px;
    font-weight: 900;
    box-shadow: 0 8px 18px var(--shadow);
  }
  
  .actionbtn.secondary{
    background: transparent;
    box-shadow: none;
  }
  
  .hint{
    font-size: 16px;
    color: var(--muted2);
    font-weight: 700;
  }
  
  /* Scrollbars minimieren (nicht perfekt möglich) */
  body.kiosk{
    overflow: hidden;
  }
  body.kiosk .content{
    overflow: hidden;
  }
  
  /* Tablet */
  @media (max-width: 900px){
    .topbar{
      grid-template-columns: 1fr;
    }
    .adminlink{
      justify-content: flex-start;
    }
    .clockblock{
      min-width: unset;
    }
  }
  
  /* MUSIC GRID */
  .musicgrid{
    margin-top: 16px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
  }
  
  .musiccard{
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 12px;
  
    background: var(--panel);
    border: 2px solid var(--border);
    border-radius: 18px;
    padding: 16px;
  
    box-shadow: 0 10px 22px var(--shadow);
  }
  
  .musiccard:focus{
    outline: 4px solid rgba(0,124,145,0.7);
    outline-offset: 4px;
  }
  
  .cover{
    border-radius: 16px;
    overflow: hidden;
    border: 2px solid var(--border);
    background: #f2f4f8;
    aspect-ratio: 1 / 1;
    display: grid;
    place-items: center;
  }
  
  .cover img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  
  .nocover{
    font-size: 64px;
    opacity: 0.9;
  }
  
  .minfo{
    display: grid;
    gap: 6px;
  }
  
  .malbum{
    font-size: 22px;
    font-weight: 950;
    line-height: 1.2;
  }
  
  .martist{
    font-size: 18px;
    font-weight: 900;
    color: var(--accent2);
  }
  
  .myear{
    font-size: 18px;
    font-weight: 900;
    color: var(--muted);
  }
  
  /* falls du .mopen noch irgendwo nutzt: light version */
  .mopen{
    font-size: 22px;
    font-weight: 950;
    padding: 14px 16px;
    border-radius: 16px;
    text-align: center;
  
    background: rgba(202,164,0,0.12);
    border: 2px solid rgba(202,164,0,0.35);
  }
  
  /* Kiosk: noch größer */
  body.kiosk .musicgrid{
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  }
  
  body.kiosk .malbum{ font-size: 26px; }
  body.kiosk .martist, body.kiosk .myear{ font-size: 20px; }
  body.kiosk .mopen{ font-size: 26px; padding: 18px 18px; }
  
  /* Admin: große Textarea */
  .bigtextarea{
    font-size: 18px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 2px solid var(--border);
    background: #ffffff;
    color: var(--text);
    width: 100%;
    min-height: 320px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    box-shadow: 0 8px 18px var(--shadow);
  }
  .adminnote{
    font-size: 16px;
    color: var(--muted);
    font-weight: 700;
    margin-top: 10px;
  }
  
  /* MUSIC ACTIONS */
  .music-actions{
    margin-top: 12px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }
  
  /* Musik: Cover als klarer Klickbereich */
  .musiccard .cover{
    transition: transform 0.08s ease, box-shadow 0.08s ease;
  }
  
  .musiccard:hover .cover,
  .musiccard:focus .cover{
    transform: scale(1.01);
    box-shadow: 0 0 0 4px rgba(0,124,145,0.22);
  }
  
  /* =========================
     WEATHER (Senior UX)
     ========================= */
  
  .weather-hero{
    margin-top: 16px;
    padding: 18px;
    border-radius: 20px;
    border: 2px solid var(--border);
    background: linear-gradient(180deg, rgba(0,124,145,0.12), rgba(202,164,0,0.08));
    box-shadow: 0 10px 22px var(--shadow);
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 16px;
    align-items: center;
  }
  
  .wh-emoji{
    font-size: 84px;
    text-align: center;
  }
  
  .wh-temp{
    font-size: 74px;
    font-weight: 950;
    line-height: 1;
  }
  
  .wh-label{
    font-size: 24px;
    font-weight: 900;
    color: var(--muted);
    margin-top: 6px;
  }
  
  .wh-row{
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
  
  .wh-pill{
    font-size: 18px;
    font-weight: 800;
    padding: 10px 12px;
    border-radius: 16px;
    border: 2px solid var(--border);
    background: rgba(17,19,24,0.04);
    color: var(--text);
  }
  
  .weather-today,
  .weather-hourly,
  .weather-daily{
    margin-top: 16px;
    padding: 18px;
    border-radius: 18px;
    border: 2px solid var(--border);
    background: var(--panel);
    box-shadow: 0 10px 22px var(--shadow);
  }
  
  .weather-today h2,
  .weather-hourly h2,
  .weather-daily h2{
    margin: 0 0 12px 0;
    font-size: 26px;
    font-weight: 950;
  }
  
  .today-box{
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 12px;
    align-items: center;
  }
  
  .today-emoji{
    font-size: 64px;
    text-align: center;
  }
  
  .today-label{
    font-size: 22px;
    font-weight: 950;
  }
  
  .today-temps{
    margin-top: 6px;
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 20px;
    font-weight: 900;
    color: var(--text);
  }
  
  .today-temps .max{ color: var(--accent); }
  .today-temps .min{ color: var(--accent2); }
  
  .today-meta{
    margin-top: 8px;
    font-size: 18px;
    font-weight: 800;
    color: var(--muted);
  }
  
  /* Hourly tiles */
  .hourly-grid{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 12px;
  }
  
  .hour-tile{
    border-radius: 18px;
    border: 2px solid var(--border);
    background: #ffffff;
    padding: 14px;
    text-align: center;
    box-shadow: 0 8px 18px var(--shadow);
  }
  
  .hour-time{
    font-size: 18px;
    font-weight: 950;
    color: var(--muted);
  }
  
  .hour-emoji{
    font-size: 44px;
    margin: 8px 0;
  }
  
  .hour-temp{
    font-size: 34px;
    font-weight: 950;
    line-height: 1;
  }
  
  .hour-meta{
    margin-top: 8px;
    font-size: 16px;
    font-weight: 800;
    color: var(--muted);
  }
  
  /* Daily list */
  .daily-list{
    display: grid;
    gap: 10px;
  }
  
  .day-row{
    display: grid;
    grid-template-columns: 1fr 70px 140px 1fr;
    gap: 10px;
    align-items: center;
  
    padding: 12px 14px;
    border-radius: 16px;
    border: 2px solid var(--border);
    background: #ffffff;
    box-shadow: 0 8px 18px var(--shadow);
  }
  
  .day-date{
    font-size: 18px;
    font-weight: 950;
    color: var(--text);
  }
  
  .day-emoji{
    font-size: 34px;
    text-align: center;
  }
  
  .day-temp{
    display: flex;
    justify-content: center;
    gap: 12px;
    font-size: 20px;
    font-weight: 950;
  }
  
  .day-temp .max{ color: var(--accent); }
  .day-temp .min{ color: var(--accent2); }
  
  .day-rain{
    font-size: 18px;
    font-weight: 900;
    color: var(--muted);
    text-align: right;
  }
  
  /* Kiosk: alles noch größer */
  body.kiosk .weather-hero{
    grid-template-columns: 150px 1fr;
  }
  
  body.kiosk .wh-emoji{ font-size: 96px; }
  body.kiosk .wh-temp{ font-size: 86px; }
  body.kiosk .wh-label{ font-size: 28px; }
  body.kiosk .wh-pill{ font-size: 20px; padding: 12px 14px; }
  
  body.kiosk .hourly-grid{
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
  
  body.kiosk .hour-temp{ font-size: 38px; }
  body.kiosk .today-label{ font-size: 26px; }
  