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

:root{
  --primary:#7c5ce7;
  --primary-hover:#6c4fd6;
  --primary-glow:rgba(124,92,231,0.4);

  /* Dark mode (default) - xAI SuperGrok style */
  --bg:#000000;
  --glass-bg:rgba(20,20,25,0.95);
  --glass-border:rgba(255,255,255,0.1);
  --text:#ffffff;
  --text-secondary:rgba(255,255,255,0.6);
  --text-muted:rgba(255,255,255,0.35);
}

[data-theme="light"]{
  --bg:#ffffff;
  --glass-bg:rgba(245,245,250,0.95);
  --glass-border:rgba(0,0,0,0.1);
  --text:#000000;
  --text-secondary:rgba(0,0,0,0.6);
  --text-muted:rgba(0,0,0,0.35);
}

html{
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
  color:var(--text);
  transition:color .3s ease;
}

/* Background - xAI SuperGrok style */
.background{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index:-2;
  background:var(--bg);
  transition:background .3s ease;
}

/* Stars - xAI style */
.stars{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:-1;
}

[data-theme="light"] .stars{
  display:none;
}

.star{
  position:absolute;
  width:1px;
  height:1px;
  background:#fff;
  border-radius:50%;
  opacity:0;
  animation:
    twinkle var(--duration,4s) ease-in-out infinite,
    drift var(--drift-duration,120s) linear infinite;
  animation-delay:var(--delay,0s);
}

.star.medium{
  width:2px;
  height:2px;
}

.star.large{
  width:2px;
  height:2px;
  box-shadow:0 0 4px 1px rgba(255,255,255,0.5);
}

@keyframes twinkle{
  0%,100%{opacity:0}
  50%{opacity:0.9}
}

@keyframes drift{
  0%{transform:translate(0,0)}
  25%{transform:translate(var(--drift-x,30px),var(--drift-y,20px))}
  50%{transform:translate(var(--drift-x2,50px),var(--drift-y2,40px))}
  75%{transform:translate(var(--drift-x3,20px),var(--drift-y3,60px))}
  100%{transform:translate(0,0)}
}

/* Shooting Star */
.shooting-star{
  position:absolute;
  width:2px;
  height:2px;
  background:#fff;
  border-radius:50%;
  box-shadow:
    0 0 6px 2px rgba(255,255,255,0.6),
    0 0 12px 4px rgba(255,255,255,0.3);
  animation:shoot var(--shoot-duration,1.5s) ease-out forwards;
}

.shooting-star::after{
  content:'';
  position:absolute;
  top:50%;
  right:100%;
  width:80px;
  height:1px;
  background:linear-gradient(to left,rgba(255,255,255,0.8),transparent);
  transform:translateY(-50%);
}

@keyframes shoot{
  0%{
    opacity:1;
    transform:translate(0,0) rotate(var(--angle,215deg));
  }
  70%{
    opacity:1;
  }
  100%{
    opacity:0;
    transform:translate(var(--shoot-x,300px),var(--shoot-y,300px)) rotate(var(--angle,215deg));
  }
}

/* Layout */
.app{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  padding:1.5rem 2rem;
}

/* Header */
header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  animation:fadeIn .8s ease-out;
  position:relative;
  min-height:48px;
}

header nav{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
}

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

.logo{
  display:flex;
  align-items:center;
  gap:.625rem;
  text-decoration:none;
}

.logo-icon{
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.logo-text{
  font-size:1.375rem;
  font-weight:700;
  letter-spacing:-.5px;
  color:var(--text);
}

.logo-text span{
  opacity:.5;
  font-weight:500;
}

/* Menu Toggle (Hamburger) */
.menu-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  color:var(--text);
  font-size:1.25rem;
  cursor:pointer;
  transition:all .25s ease;
  line-height:1;
}

.menu-toggle:hover{
  background:rgba(255,255,255,0.1);
  transform:scale(1.05);
}

/* Mobile Menu */
.mobile-menu-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.7);
  backdrop-filter:blur(4px);
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
  z-index:999;
}

.mobile-menu-overlay.active{
  opacity:1;
  pointer-events:all;
}

.mobile-menu{
  position:fixed;
  top:0;
  right:0;
  width:280px;
  height:100vh;
  background:var(--bg);
  border-left:1px solid var(--glass-border);
  transform:translateX(100%);
  transition:transform .3s ease;
  z-index:1000;
  padding:2rem 1.5rem;
}

.mobile-menu.active{
  transform:translateX(0);
}

.mobile-menu-close{
  position:absolute;
  top:1rem;
  right:1rem;
  width:40px;
  height:40px;
  border:none;
  background:var(--glass-bg);
  border-radius:10px;
  color:var(--text);
  font-size:1.5rem;
  cursor:pointer;
  transition:all .25s ease;
  line-height:1;
}

.mobile-menu-close:hover{
  background:rgba(255,255,255,0.1);
  transform:scale(1.1);
}

.mobile-menu-items{
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-top:4rem;
}

.mobile-menu-item{
  padding:1rem 1.5rem;
  border-radius:12px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  color:var(--text);
  text-decoration:none;
  font-weight:500;
  font-size:1.1rem;
  transition:all .25s ease;
  text-align:center;
}

.mobile-menu-item:hover{
  background:rgba(255,255,255,0.1);
  transform:translateX(-4px);
}

/* Header Controls */
.header-controls{
  display:flex;
  align-items:center;
  gap:.75rem;
}

.theme-toggle{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  color:var(--text-secondary);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.125rem;
  transition:all .25s ease;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.theme-toggle:hover{
  background:rgba(124,92,231,0.15);
  color:var(--text);
  transform:translateY(-2px);
}

/* Navigation */
nav{
  display:flex;
  gap:.375rem;
  padding:.25rem;
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-radius:100px;
  border:1px solid var(--glass-border);
}

.nav-btn{
  padding:.75rem 1.5rem;
  border:none;
  background:transparent;
  color:var(--text-secondary);
  font-family:inherit;
  font-size:.9rem;
  font-weight:500;
  border-radius:100px;
  cursor:pointer;
  transition:all .25s ease;
  text-decoration:none;
  display:inline-block;
}

.nav-btn:hover{
  color:var(--text);
  background:rgba(255,255,255,0.05);
}

.nav-btn.active{
  background:var(--primary);
  color:#fff;
  box-shadow:0 4px 20px var(--primary-glow);
}

/* Main Content */
main{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:2rem;
  transform:translateY(2vh);
  animation:fadeUp .8s ease-out .2s both;
}

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

/* Pomodoro Mode Selector */
.pomo-modes{
  display:none;
  gap:.5rem;
}

.pomo-modes.visible{
  display:flex;
}

.pomo-btn{
  padding:.625rem 1.5rem;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  color:var(--text-secondary);
  font-family:inherit;
  font-size:.95rem;
  font-weight:500;
  border-radius:100px;
  cursor:pointer;
  transition:all .25s ease;
}

.pomo-btn:hover{
  color:var(--text);
  background:rgba(255,255,255,0.1);
}

.pomo-btn.active{
  background:rgba(124,92,231,0.2);
  border-color:var(--primary);
  color:var(--text);
}

/* Timer Input */
.timer-input-container{
  display:none;
  align-items:center;
  gap:.75rem;
  margin-top:4.5rem;
}

.timer-input-container.visible{
  display:flex;
}

.timer-input-group{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.25rem;
}

.timer-input{
  width:72px;
  padding:.875rem .5rem;
  background:#1a1a1f;
  border:1px solid rgba(124,92,231,0.3);
  border-radius:12px;
  color:var(--text);
  font-family:inherit;
  font-size:1.5rem;
  font-weight:700;
  text-align:center;
  -moz-appearance:textfield;
}

[data-theme="light"] .timer-input{
  background:#f0f0f5;
  border-color:rgba(124,92,231,0.4);
}

/* Spinner buttons - hidden, no space */
.timer-input::-webkit-outer-spin-button,
.timer-input::-webkit-inner-spin-button{
  -webkit-appearance:none;
  appearance:none;
  margin:0;
}

.timer-input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(124,92,231,0.2);
}

.timer-input-label{
  font-size:.7rem;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:1px;
  margin-top:.25rem;
}

.timer-input-sep{
  font-size:2rem;
  color:var(--text-muted);
  font-weight:300;
  margin:0 .25rem;
  align-self:flex-start;
  margin-top:.5rem;
}

.alarm-info{
  display:none;
  font-size:.9rem;
  color:var(--text-secondary);
  margin-top:-1rem;
  margin-bottom:-1.5rem;
  min-height:1.4em;
}
.alarm-info.visible{
  display:block;
}

/* Timer Presets */
.timer-presets{
  display:none;
  flex-wrap:wrap;
  gap:.5rem;
  justify-content:center;
  margin-top:1rem;
}

.timer-presets.visible{
  display:flex;
}

#timerPresets{
  margin-top:.6rem;
}

#timerPresetsHours{
  margin-top:-1.6rem;
}

.timer-preset-btn{
  padding:.5rem 1rem;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  color:var(--text-secondary);
  font-family:inherit;
  font-size:.8rem;
  font-weight:500;
  border-radius:100px;
  cursor:pointer;
  transition:all .25s ease;
}

.timer-preset-btn:hover{
  color:var(--text);
  background:rgba(124,92,231,0.15);
  border-color:var(--primary);
}

/* Timer Display */
.timer-display{
  font-size:clamp(5rem,18vw,180px);
  font-weight:700;
  letter-spacing:-.03em;
  color:var(--text);
  text-shadow:0 4px 60px rgba(0,0,0,0.2);
  line-height:1;
  font-variant-numeric:tabular-nums;
  transition:transform .3s ease;
}

.timer-display.small{
  font-size:clamp(4rem,15vw,180px);
}

.timer-ms{
  font-size:.35em;
  opacity:.5;
  font-weight:500;
}

.timer-display.pulse{
  animation:timerPulse .5s ease;
}

@keyframes timerPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.02)}
}

/* Date Display (Alarm) */
.date-display{
  display:none;
  font-size:1.1rem;
  color:var(--text-secondary);
  margin-top:-1rem;
}

.date-display.visible{
  display:block;
}

/* Pomodoro Streak Counter */
.pomo-streak{
  display:none;
  align-items:center;
  gap:.5rem;
  padding:.5rem 1.25rem;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:100px;
  backdrop-filter:blur(10px);
}

.pomo-streak.visible{
  display:flex;
}

.pomo-streak-icon{
  font-size:1.25rem;
}

.pomo-streak-count{
  font-size:1.1rem;
  font-weight:700;
  color:var(--text);
}

.pomo-streak-clear{
  width:20px;
  height:20px;
  border:none;
  background:rgba(255,255,255,0.1);
  color:var(--text-muted);
  border-radius:50%;
  cursor:pointer;
  font-size:.65rem;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-left:.25rem;
  transition:all .2s ease;
}

.pomo-streak-clear:hover{
  background:rgba(255,255,255,0.2);
  color:var(--text);
}

/* Controls */
.controls{
  display:flex;
  align-items:center;
  gap:1rem;
}

.control-btn{
  width:50px;
  height:50px;
  border-radius:50%;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  color:var(--text-secondary);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.25rem;
  transition:all .25s ease;
}

.control-btn:hover{
  background:rgba(255,255,255,0.12);
  color:var(--text);
  transform:scale(1.05);
}

.control-btn.hidden{
  display:none;
}

.play-btn{
  padding:1rem 2.5rem;
  border-radius:100px;
  border:none;
  background:var(--primary);
  color:#fff;
  font-family:inherit;
  font-size:1.1rem;
  font-weight:600;
  cursor:pointer;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  box-shadow:0 8px 30px var(--primary-glow);
  min-width:140px;
}

.play-btn:hover{
  background:var(--primary-hover);
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(124,92,231,0.5);
}

.play-btn:active{
  transform:translateY(0);
}

/* Laps Container */
.laps-container{
  display:none;
  width:100%;
  max-width:380px;
  max-height:160px;
  overflow-y:auto;
  margin-top:1rem;
}

.laps-container.visible{
  display:block;
}

.laps-container::-webkit-scrollbar{
  width:4px;
}

.laps-container::-webkit-scrollbar-track{
  background:transparent;
}

.laps-container::-webkit-scrollbar-thumb{
  background:var(--glass-border);
  border-radius:4px;
}

.lap-item{
  display:flex;
  justify-content:space-between;
  padding:.625rem 1rem;
  border-bottom:1px solid var(--glass-border);
  font-size:.9rem;
  animation:lapIn .3s ease;
}

@keyframes lapIn{
  from{opacity:0;transform:translateX(-10px)}
  to{opacity:1;transform:translateX(0)}
}

.lap-item span:first-child{
  color:var(--text-secondary);
}

.lap-item span:last-child{
  font-weight:600;
  font-variant-numeric:tabular-nums;
}

/* Footer */
footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  animation:fadeUp .8s ease-out .4s both;
}

.footer-left,.footer-right{
  display:flex;
  align-items:center;
  gap:.625rem;
}

.footer-btn{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  color:var(--text-secondary);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
  transition:all .25s ease;
}

.footer-btn:hover{
  background:rgba(255,255,255,0.12);
  color:var(--text);
  transform:translateY(-2px);
}

.footer-btn.active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}

#fullscreenBtn{
  text-indent:-0.5px;
  line-height:1.03;
}

.footer-group{
  display:flex;
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:14px;
  padding:.25rem;
  gap:.25rem;
}

.footer-group .footer-btn{
  background:transparent;
  border:none;
  backdrop-filter:none;
}

.footer-group .footer-btn:hover{
  background:rgba(255,255,255,0.08);
}

.footer-group .footer-btn.active{
  background:var(--primary);
}


/* Settings Panel */
.settings-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:99;
  opacity:0;
  visibility:hidden;
  transition:all .3s ease;
}

.settings-overlay.active{
  opacity:1;
  visibility:visible;
}

.settings-panel{
  position:fixed;
  top:0;
  right:-400px;
  width:380px;
  max-width:90vw;
  height:100vh;
  background:#0a0a0f;
  border-left:1px solid var(--glass-border);
  padding:1.5rem;
  z-index:100;
  transition:right .4s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}

[data-theme="light"] .settings-panel{
  background:#f5f5fa;
}

.settings-panel.active{
  right:0;
}

.settings-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:2rem;
}

.settings-header h2{
  font-size:1.375rem;
  font-weight:700;
}

.settings-close{
  width:40px;
  height:40px;
  border-radius:10px;
  border:none;
  background:var(--glass-bg);
  color:var(--text);
  cursor:pointer;
  font-size:1.25rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .2s ease;
}

.settings-close:hover{
  background:rgba(255,255,255,0.12);
}

.settings-section{
  margin-bottom:1.5rem;
}

.settings-section h3{
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--text-secondary);
  margin-bottom:.75rem;
}

.settings-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:.875rem 0;
  border-bottom:1px solid var(--glass-border);
}

.settings-row label{
  font-size:.95rem;
}

.settings-input{
  width:70px;
  padding:.5rem .75rem;
  border-radius:8px;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  color:var(--text);
  font-family:inherit;
  font-size:.95rem;
  text-align:center;
}

.settings-input:focus{
  outline:none;
  border-color:var(--primary);
}

/* Toggle Switch */
.toggle{
  position:relative;
  width:48px;
  height:26px;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:100px;
  cursor:pointer;
  transition:all .3s ease;
}

.toggle.active{
  background:var(--primary);
  border-color:var(--primary);
}

.toggle::after{
  content:'';
  position:absolute;
  top:2px;
  left:2px;
  width:20px;
  height:20px;
  background:#fff;
  border-radius:50%;
  transition:transform .3s ease;
}

.toggle.active::after{
  transform:translateX(22px);
}

/* Focus Mode */
.focus-mode .background::after{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.3);
  animation:focusPulse 4s ease-in-out infinite;
}

@keyframes focusPulse{
  0%,100%{opacity:0.3}
  50%{opacity:0.5}
}

.focus-mode header{
  opacity:0.3;
  transition:opacity .3s ease;
}

.focus-mode header:hover{
  opacity:1;
}

.focus-mode .footer-btn{
  opacity:0.3;
  transition:opacity .3s ease;
}

.focus-mode .footer-btn:hover{
  opacity:1;
}

.focus-mode .footer-links{
  opacity:0;
  pointer-events:none;
}

/* Focus mode - hide elements per mode */
.focus-mode .controls{
  opacity:0.2;
  transition:opacity .3s ease;
}
.focus-mode .controls:hover{
  opacity:1;
}

/* Cronómetro: hide laps */
.focus-mode .laps-container{
  opacity:0;
  pointer-events:none;
}

/* Temporizador: hide inputs and presets */
.focus-mode .timer-input-container,
.focus-mode .timer-presets{
  opacity:0;
  pointer-events:none;
}

/* Pomodoro: hide mode buttons and streak */
.focus-mode .pomo-modes,
.focus-mode .pomo-streak{
  opacity:0;
  pointer-events:none;
}

/* Alarme: hide inputs, presets, date (keep time and "Toca em") */
.focus-mode #alarmInput,
.focus-mode #alarmPresets,
.focus-mode .date-display{
  opacity:0;
  pointer-events:none;
}

/* Notification */
.notification{
  position:fixed;
  top:5.5rem;
  left:50%;
  transform:translateX(-50%) translateY(-200px);
  background:var(--glass-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  padding:1rem 2rem;
  border-radius:100px;
  font-weight:500;
  font-size:.95rem;
  z-index:200;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}

.notification.show{
  transform:translateX(-50%) translateY(0);
}

/* Celebration */
.celebration{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:150;
}

.confetti{
  position:absolute;
  top:0;
  width:10px;
  height:10px;
  animation:confettiFall 2.5s cubic-bezier(.25,.46,.45,.94) forwards;
  will-change:transform,opacity;
}

@keyframes confettiFall{
  0%{transform:translateY(0) rotate(0deg);opacity:1}
  100%{transform:translateY(100vh) rotate(720deg);opacity:0}
}

/* Responsive */
@media(max-width:768px){
  .app{
    padding:1rem;
  }

  header{
    display:grid;
    grid-template-columns:1fr auto;
    gap:.75rem;
  }

  .logo{
    grid-column:1;
    grid-row:1;
  }

  .header-controls{
    grid-column:2;
    grid-row:1 / 3;
    flex-direction:column;
    gap:.5rem;
    justify-content:flex-start;
    align-items:flex-end;
  }

  .menu-toggle{
    display:block;
  }

  nav{
    display:none;
  }

  .nav-btn{
    padding:.625rem 1rem;
    font-size:.85rem;
  }

  .timer-display{
    font-size:clamp(2.5rem,12vw,5rem);
  }

  .timer-display.small{
    font-size:clamp(3rem,14vw,6rem);
  }

  .play-btn{
    padding:.875rem 2rem;
    font-size:1rem;
    min-width:120px;
  }

  .control-btn{
    width:44px;
    height:44px;
  }

  footer{
    flex-direction:column;
    gap:1.5rem;
    align-items:center;
    margin-top:2rem;
  }

  .footer-left{
    width:100%;
    justify-content:center;
    order:2;
  }

  .footer-right{
    width:100%;
    justify-content:center;
    order:1;
  }

  .footer-links{
    justify-content:center !important;
  }
}

@media(max-width:480px){
  .nav-btn{
    padding:.5rem .75rem;
    font-size:.8rem;
  }

  .pomo-btn{
    padding:.4rem .875rem;
    font-size:.8rem;
  }


  .timer-input{
    font-size:2rem;
    padding:.5rem;
    min-width:60px;
  }

  .timer-input-label{
    font-size:.7rem;
  }

  .timer-preset-btn{
    padding:.6rem .875rem;
    font-size:.85rem;
    min-width:60px;
  }

  .settings-panel{
    width:90%;
    max-width:none;
  }

  .logo-text{
    font-size:1rem;
  }

  .footer-btn{
    width:40px;
    height:40px;
    font-size:1.1rem;
  }

  .timer-display{
    font-size:clamp(2rem,15vw,4rem);
  }

  .timer-display.small{
    font-size:clamp(2.5rem,18vw,5rem);
  }

  .date-display{
    font-size:.75rem;
  }

  .alarm-info{
    font-size:.85rem;
  }
}

/* Hidden utility */
.hidden{
  display:none!important;
}
