/* ============================================================
   TOM LOUVORES — INVB — style.css
   ============================================================ */

   @import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700;900&display=swap');

   *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
   
   :root{
     --black:  #0A0A0A;
     --black2: #111111;
     --black3: #1A1A1A;
     --black4: #242424;
     --black5: #2E2E2E;
     --yellow: #FFE000;
     --yellow2:#FFC800;
     --gray:   #888;
     --gray2:  #555;
     --gray3:  #333;
     --white:  #FFFFFF;
     --r: 6px;
   }
   
   body{
     font-family:'Inter',sans-serif;
     background:var(--black);
     color:var(--white);
     min-height:100vh;
     overflow-x:hidden;
   }
   
   /* ——— HEADER ——— */
   .header{
     background:var(--black);
     border-bottom:1px solid var(--black4);
     position:sticky;top:0;z-index:100;
   }
   .header-inner{
     max-width:1280px;margin:0 auto;
     padding:0 36px;height:64px;
     display:flex;align-items:center;justify-content:space-between;
   }
   .logo{display:flex;align-items:center;gap:12px}
   .logo-img{
     height:30px;width:auto;
     mix-blend-mode:screen;
   }
   .logo-wordmark{
     font-family:'Bebas Neue',sans-serif;
     font-size:28px;letter-spacing:0.06em;
     line-height:1;color:var(--white);
   }
   .logo-wordmark span{color:var(--yellow)}
   .logo-sep{width:1px;height:28px;background:var(--black5)}
   .logo-sub{
     font-size:10px;font-weight:600;
     color:var(--yellow);letter-spacing:0.16em;
     text-transform:uppercase;line-height:1.3;
   }
   .header-right{display:flex;align-items:center;gap:10px}
   
   .status-pill{
     display:flex;align-items:center;gap:7px;
     padding:6px 12px;
     border:1px solid var(--black5);
     font-size:11px;font-weight:500;
     color:var(--gray);letter-spacing:0.04em;
     text-transform:uppercase;
     background:var(--black2);
     border-radius:2px;
   }
   .status-pill.ok {color:#4ADE80;border-color:rgba(74,222,128,0.3)}
   .status-pill.err{color:#F87171;border-color:rgba(248,113,113,0.3)}
   .dot{
     width:6px;height:6px;border-radius:50%;
     background:currentColor;
     animation:blink 2s ease infinite;flex-shrink:0;
   }
   @keyframes blink{0%,100%{opacity:1}50%{opacity:0.2}}
   
   .btn-add{
     display:flex;align-items:center;gap:8px;
     padding:10px 20px;
     background:var(--yellow);
     border:none;cursor:pointer;
     font-family:'Inter',sans-serif;
     font-size:13px;font-weight:700;
     color:var(--black);
     letter-spacing:0.05em;text-transform:uppercase;
     transition:background 0.15s;
     border-radius:var(--r);
   }
   .btn-add:hover{background:var(--yellow2)}
   .btn-add:active{transform:scale(0.98)}
   
   /* ——— HERO OUTER (full-width background) ——— */
   .hero-outer{
     background:url('image.jpg') center 30% / cover no-repeat;
     position:relative;
     border-bottom:1px solid var(--black4);
   }
   .hero-outer::before{
     content:'';
     position:absolute;inset:0;
     background:rgba(0,0,0,0.76);
     pointer-events:none;
   }
   
   /* ——— HERO (inner content container) ——— */
   .hero{
     max-width:1280px;margin:0 auto;
     padding:52px 36px 40px;
     display:grid;grid-template-columns:1fr auto;
     gap:48px;align-items:end;
     position:relative;z-index:1;
   }
   
   /* ——— HERO RIGHT COLUMN (brand logo + stats) ——— */
   .hero-right-col{
     display:flex;flex-direction:column;
     align-items:center;gap:20px;
     align-self:end;
   }
   
   .hero-tag{
     display:inline-flex;align-items:center;gap:8px;
     background:var(--yellow);
     color:var(--black);
     font-size:10px;font-weight:800;
     letter-spacing:0.14em;text-transform:uppercase;
     padding:4px 12px;border-radius:2px;
     margin-bottom:20px;
   }
   .hero-h1{
     font-family:'Bebas Neue',sans-serif;
     font-size:clamp(52px,7vw,88px);
     line-height:0.9;letter-spacing:0.03em;
     color:var(--white);
   }
   .hero-h1 em{color:var(--yellow);font-style:normal}
   .hero-sub{
     font-size:14px;font-weight:300;
     color:var(--gray);margin-top:14px;line-height:1.65;
   }
   .hero-stats{
     display:flex;flex-direction:column;
     border:1px solid var(--black5);
     background:rgba(17,17,17,0.85);
     border-radius:var(--r);
     overflow:hidden;
     align-self:stretch;
     min-width:200px;
   }
   .stat-row{
     padding:18px 24px;
     display:flex;align-items:baseline;justify-content:space-between;
     gap:16px;
     border-bottom:1px solid var(--black4);
   }
   .stat-row:last-child{border-bottom:none}
   .stat-n{
     font-family:'Bebas Neue',sans-serif;
     font-size:44px;line-height:1;letter-spacing:0.02em;
     color:var(--yellow);
   }
   .stat-l{
     font-size:10px;font-weight:600;
     color:var(--gray2);letter-spacing:0.1em;
     text-transform:uppercase;
   }
   
   /* ——— TOOLBAR ——— */
   .toolbar{
     max-width:1280px;margin:28px auto 0;padding:0 36px;
     display:flex;gap:10px;flex-wrap:wrap;align-items:center;
   }
   .search-wrap{flex:1;min-width:220px;position:relative}
   .search-ico{
     position:absolute;left:13px;top:50%;transform:translateY(-50%);
     color:var(--gray2);pointer-events:none;font-size:15px;
   }
   .inp-search{
     width:100%;
     background:var(--black2);
     border:1px solid var(--black5);
     color:var(--white);
     padding:11px 14px 11px 38px;
     border-radius:var(--r);
     font-family:'Inter',sans-serif;font-size:13px;
     outline:none;transition:border-color 0.2s;
   }
   .inp-search:focus{border-color:var(--yellow)}
   .inp-search::placeholder{color:var(--gray2)}
   .sel{
     background:var(--black2);
     border:1px solid var(--black5);
     color:var(--gray);
     padding:11px 14px;border-radius:var(--r);
     font-family:'Inter',sans-serif;font-size:13px;
     outline:none;cursor:pointer;
     transition:border-color 0.2s;min-width:165px;
   }
   .sel:focus{border-color:var(--yellow)}
   .sel option{background:var(--black2);color:var(--white)}
   .count-badge{
     font-size:11px;font-weight:600;
     color:var(--yellow);
     background:rgba(255,224,0,0.1);
     border:1px solid rgba(255,224,0,0.25);
     padding:5px 12px;border-radius:2px;
     letter-spacing:0.06em;white-space:nowrap;
     text-transform:uppercase;
   }
   
   /* ——— GRID ——— */
   .grid-wrap{max-width:1280px;margin:20px auto 80px;padding:0 36px}
   .grid{
     display:grid;
     grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
     gap:12px;
   }
   
   /* ——— CARD ——— */
   .card{
     background:var(--black2);
     border:1px solid var(--black4);
     border-radius:var(--r);
     padding:22px 22px 18px;
     display:flex;flex-direction:column;gap:14px;
     cursor:default;
     transition:border-color 0.2s,background 0.2s;
     position:relative;overflow:hidden;
   }
   .card::before{
     content:'';
     position:absolute;top:0;left:0;right:0;
     height:2px;background:var(--black4);
     transition:background 0.2s;
   }
   .card:hover{background:var(--black3);border-color:var(--black5)}
   .card:hover::before{background:var(--yellow)}
   .card-editable{cursor:pointer}
   .card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
   .act-btn.del{
     width:26px;height:26px;flex-shrink:0;
     background:transparent;
     border:1px solid transparent;
     display:flex;align-items:center;justify-content:center;
     cursor:pointer;color:var(--gray2);
     transition:all 0.15s;border-radius:4px;font-size:12px;
     opacity:0;
   }
   .card:hover .act-btn.del{opacity:1}
   .act-btn.del:hover{background:rgba(248,113,113,0.1);color:#F87171;border-color:rgba(248,113,113,0.3)}
   
   .card-nome{
     font-size:17px;font-weight:700;line-height:1.25;
     color:var(--white);letter-spacing:-0.01em;
     min-height:calc(17px * 1.25 * 2);
     display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
   }
   .card-obs{
     font-size:12px;color:var(--gray);line-height:1.6;font-weight:300;
     display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
   }
   
   .card-tons{display:flex;flex-direction:column;gap:6px}
   .card-ton-row{
     display:flex;align-items:center;justify-content:space-between;gap:8px;
   }
   .card-badge{
     font-family:'Bebas Neue',sans-serif;
     font-size:20px;letter-spacing:0.04em;
     line-height:1;color:var(--yellow);
     background:rgba(255,224,0,0.08);
     border:1px solid rgba(255,224,0,0.2);
     padding:3px 10px;border-radius:4px;
     flex-shrink:0;min-width:48px;text-align:center;
   }
   .card-min-label{
     font-size:10px;font-weight:700;
     padding:3px 10px;
     letter-spacing:0.08em;text-transform:uppercase;
     border:1px solid;border-radius:2px;
   }
   
   .chip-Raphaela{background:rgba(255,224,0,0.1);color:#FFE000;border-color:rgba(255,224,0,0.3)}
   .chip-Daniela {background:rgba(96,165,250,0.1);color:#60A5FA;border-color:rgba(96,165,250,0.3)}
   .chip-Cris    {background:rgba(74,222,128,0.1);color:#4ADE80;border-color:rgba(74,222,128,0.3)}
   .chip-Mirian  {background:rgba(251,146,60,0.1);color:#FB923C;border-color:rgba(251,146,60,0.3)}
   .chip-Humberto{background:rgba(167,139,250,0.1);color:#A78BFA;border-color:rgba(167,139,250,0.3)}
   
   .card-foot{
     display:flex;align-items:center;justify-content:flex-end;
     padding-top:10px;border-top:1px solid var(--black4);margin-top:auto;
   }
   .card-date{font-size:10px;color:var(--gray2);font-weight:400;letter-spacing:0.04em}
   
   /* ——— STATES ——— */
   .state-loading,.state-empty{
     grid-column:1/-1;
     display:none;flex-direction:column;align-items:center;
     gap:14px;padding:90px 24px;
     color:var(--gray);text-align:center;
   }
   .state-loading{display:flex}
   .spinner{
     width:36px;height:36px;
     border:2px solid var(--black5);
     border-top-color:var(--yellow);
     border-radius:50%;
     animation:spin 0.7s linear infinite;
   }
   @keyframes spin{to{transform:rotate(360deg)}}
   .empty-sym{
     font-family:'Bebas Neue',sans-serif;
     font-size:64px;letter-spacing:0.06em;
     color:var(--black5);line-height:1;
   }
   .empty-ttl{font-size:18px;font-weight:700;color:var(--black5)}
   .empty-sub{font-size:13px;color:var(--gray2)}
   
   /* ——— MODAL MÚSICA ——— */
   .overlay-bg{
     position:fixed;inset:0;
     background:rgba(0,0,0,0.82);
     display:none;align-items:center;justify-content:center;
     padding:24px;z-index:200;
   }
   .overlay-bg.open{display:flex}
   .modal{
     background:var(--black2);
     border:1px solid var(--black5);
     width:100%;max-width:500px;
     border-radius:10px;overflow:hidden;
     max-height:90vh;display:flex;flex-direction:column;
   }
   .modal-hd{
     padding:24px 24px 20px;
     display:flex;align-items:center;justify-content:space-between;
     border-bottom:1px solid var(--black4);flex-shrink:0;
   }
   .modal-hd h2{
     font-family:'Bebas Neue',sans-serif;
     font-size:26px;letter-spacing:0.06em;color:var(--white);
   }
   .modal-close{
     width:30px;height:30px;
     background:transparent;border:1px solid var(--black5);
     color:var(--gray);font-size:14px;cursor:pointer;
     display:flex;align-items:center;justify-content:center;
     border-radius:4px;transition:all 0.15s;
   }
   .modal-close:hover{background:var(--black4);color:var(--white)}
   .modal-bd{
     padding:20px 24px;
     display:flex;flex-direction:column;gap:16px;overflow-y:auto;
   }
   .modal-ft{
     padding:14px 24px 20px;
     display:flex;gap:8px;justify-content:flex-end;
     border-top:1px solid var(--black4);flex-shrink:0;
   }
   .flabel{
     font-size:10px;font-weight:700;color:var(--gray2);
     letter-spacing:0.12em;text-transform:uppercase;
     display:block;margin-bottom:7px;
   }
   .finput{
     width:100%;
     background:var(--black3);border:1px solid var(--black5);
     color:var(--white);padding:11px 13px;
     border-radius:var(--r);
     font-family:'Inter',sans-serif;font-size:13px;
     outline:none;transition:border-color 0.2s;
   }
   .finput:focus{border-color:var(--yellow)}
   .finput::placeholder{color:var(--gray2)}
   .finput option{background:var(--black2);color:var(--white)}
   .ftextarea{resize:vertical;min-height:72px}
   
   /* ——— TOM ADD ROW ——— */
   .tom-add-row{
     display:grid;grid-template-columns:1fr 1fr auto;
     gap:8px;align-items:center;
   }
   .btn-add-tom{
     height:42px;width:42px;
     background:var(--yellow);border:none;cursor:pointer;
     font-size:22px;font-weight:700;color:var(--black);
     border-radius:var(--r);
     display:flex;align-items:center;justify-content:center;
     transition:background 0.15s;flex-shrink:0;
   }
   .btn-add-tom:hover{background:var(--yellow2)}
   
   /* ——— TOM LIST (pares adicionados) ——— */
   .tom-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
   .tom-list-item{
     display:flex;align-items:center;justify-content:space-between;
     gap:10px;
     background:var(--black3);border:1px solid var(--black5);
     border-radius:var(--r);padding:8px 12px;
   }
   .tom-list-info{display:flex;align-items:center;gap:10px}
   .tom-list-badge{
     font-family:'Bebas Neue',sans-serif;
     font-size:20px;letter-spacing:0.04em;
     color:var(--yellow);min-width:40px;text-align:center;
   }
   .tom-list-min{
     font-size:11px;font-weight:600;
     letter-spacing:0.06em;color:var(--gray);text-transform:uppercase;
   }
   .tom-list-remove{
     width:24px;height:24px;
     background:transparent;border:1px solid var(--black5);
     color:var(--gray2);font-size:12px;border-radius:4px;
     cursor:pointer;display:flex;align-items:center;justify-content:center;
     transition:all 0.15s;flex-shrink:0;
   }
   .tom-list-remove:hover{
     background:rgba(248,113,113,0.1);
     color:#F87171;border-color:rgba(248,113,113,0.3);
   }
   
   /* ——— BOTÕES MODAL ——— */
   .btn-cancel{
     padding:10px 18px;
     background:transparent;border:1px solid var(--black5);
     color:var(--gray);font-family:'Inter',sans-serif;
     font-size:13px;font-weight:500;cursor:pointer;
     transition:all 0.15s;border-radius:var(--r);
   }
   .btn-cancel:hover{background:var(--black4);color:var(--white)}
   .btn-save{
     padding:10px 22px;
     background:var(--yellow);border:none;
     color:var(--black);font-family:'Inter',sans-serif;
     font-size:13px;font-weight:800;cursor:pointer;
     transition:background 0.15s;border-radius:var(--r);
     letter-spacing:0.04em;text-transform:uppercase;
   }
   .btn-save:hover{background:var(--yellow2)}
   .btn-save:disabled{opacity:0.4;cursor:not-allowed}
   
   /* ——— TOAST ——— */
   .toast{
     position:fixed;bottom:28px;left:50%;transform:translateX(-50%);
     background:var(--black3);border:1px solid var(--black5);
     color:var(--white);padding:12px 24px;
     font-size:12px;font-weight:600;
     letter-spacing:0.04em;text-transform:uppercase;
     border-radius:4px;white-space:nowrap;
     opacity:0;pointer-events:none;
     transition:opacity 0.25s;z-index:999;
   }
   .toast.show{opacity:1}
   .toast.err{border-color:rgba(248,113,113,0.4);color:#F87171}
   
   /* ============================================================
      LOGIN / AUTH
      ============================================================ */
   
   /* Overlay do modal de login */
   #loginOverlay{
     display:none;
     position:fixed;inset:0;
     background:rgba(0,0,0,0.82);
     backdrop-filter:blur(6px);
     z-index:300;
     align-items:center;justify-content:center;
     padding:24px;
   }
   #loginOverlay.open{display:flex}
   
   /* Caixa central */
   .login-box{
     background:var(--black2);
     border:1px solid var(--black5);
     border-radius:10px;
     padding:36px 32px 28px;
     width:100%;max-width:360px;
     box-shadow:0 24px 60px rgba(0,0,0,.5);
     display:flex;flex-direction:column;gap:18px;
   }
   .login-box h2{
     font-family:'Bebas Neue',sans-serif;
     font-size:28px;letter-spacing:0.06em;
     color:var(--white);margin:0 0 2px;
   }
   .login-box p.login-sub{
     font-size:12px;color:var(--gray2);margin:0;
   }
   .login-box label{
     font-size:10px;font-weight:700;
     letter-spacing:0.12em;text-transform:uppercase;
     color:var(--gray2);display:block;margin-bottom:7px;
   }
   .login-box input{
     width:100%;box-sizing:border-box;
     background:var(--black3);
     border:1px solid var(--black5);
     color:var(--white);
     padding:11px 13px;
     border-radius:var(--r);
     font-family:'Inter',sans-serif;font-size:13px;
     outline:none;transition:border-color 0.2s;
   }
   .login-box input:focus{border-color:var(--yellow)}
   .login-box input::placeholder{color:var(--gray2)}
   
   .login-error{
     font-size:12px;font-weight:600;
     color:#F87171;min-height:16px;
   }
   
   .login-actions{
     display:flex;gap:8px;margin-top:4px;
   }
   .btn-login-cancel{
     flex:1;padding:10px 18px;
     background:transparent;border:1px solid var(--black5);
     color:var(--gray);font-family:'Inter',sans-serif;
     font-size:13px;font-weight:500;cursor:pointer;
     border-radius:var(--r);transition:all 0.15s;
   }
   .btn-login-cancel:hover{background:var(--black4);color:var(--white)}
   .btn-login-submit{
     flex:2;padding:10px 22px;
     background:var(--yellow);border:none;
     color:var(--black);font-family:'Inter',sans-serif;
     font-size:13px;font-weight:800;cursor:pointer;
     border-radius:var(--r);
     letter-spacing:0.05em;text-transform:uppercase;
     transition:background 0.15s;
   }
   .btn-login-submit:hover{background:var(--yellow2)}
   
   /* Botão Sair no header */
   .btn-logout{
     padding:9px 16px;
     border:1px solid var(--black5);
     border-radius:var(--r);
     background:transparent;
     font-family:'Inter',sans-serif;
     font-size:12px;font-weight:700;
     letter-spacing:0.05em;text-transform:uppercase;
     cursor:pointer;color:var(--gray);
     transition:all 0.15s;
   }
   .btn-logout:hover{
     background:var(--black3);
     color:var(--white);
     border-color:var(--gray3);
   }
   
   /* ——— RESPONSIVE ——— */
   @media(max-width:700px){
     .header-inner,.hero,.toolbar,.grid-wrap{padding-left:20px;padding-right:20px}
     .hero{grid-template-columns:1fr;gap:24px}
     .hero-right-col{align-self:auto;width:100%}
     /* Stats: linha horizontal ocupando 100% da largura */
     .hero-stats{
       flex-direction:row;
       width:100%;
       min-width:unset;
     }
     .stat-row{
       flex:1;
       flex-direction:column;
       align-items:center;
       justify-content:center;
       gap:4px;
       border-bottom:none;
       border-right:1px solid var(--black4);
       padding:14px 8px;
     }
     .stat-row:last-child{border-right:none}
     .stat-n{font-size:30px}
     .stat-l{font-size:9px;letter-spacing:0.06em;text-align:center}
     .act-btn.del{opacity:1}
     .grid{grid-template-columns:1fr}
     .tom-add-row{grid-template-columns:1fr 1fr auto}
   }
   @media(max-width:480px){
     .header-inner{padding:0 16px;height:56px}
     .logo-img{height:26px}
     .logo-sep{height:22px}
     .logo-sub{font-size:9px;letter-spacing:0.1em}
     .status-pill{padding:5px 8px;font-size:10px;gap:5px}
     .btn-add{padding:8px 12px;font-size:12px;letter-spacing:0.02em}
     #statusTxt{display:none}
     .login-box{padding:28px 20px 22px}
   }