/* ====== PhoneCheck Theme (Bootstrap 5 override) ====== */

:root {
    --pc-brand: #2563eb;
    --pc-brand-2: #1d4ed8;
    --pc-brand-soft: rgba(37, 99, 235, .10);

    --pc-accent: #10b981;
    --pc-accent-soft: rgba(16, 185, 129, .10);

    --pc-warning: #f59e0b;
    --pc-danger: #ef4444;

    --pc-bg: #f5f7fb;
    --pc-card: rgba(255, 255, 255, .86);
    --pc-text: #111827;
    --pc-muted: #6b7280;
    --pc-border: rgba(226, 232, 240, .95);

    --pc-shadow: 0 18px 45px rgba(15, 23, 42, .08);
    --pc-shadow-soft: 0 10px 30px rgba(15, 23, 42, .055);

    --pc-radius: 20px;
    --pc-font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

    --header-bg:
        radial-gradient(900px 380px at 15% 10%, rgba(37, 99, 235, .22), transparent 55%),
        radial-gradient(760px 360px at 88% 0%, rgba(16, 185, 129, .18), transparent 55%),
        linear-gradient(135deg, #f8fbff 0%, #eef4ff 52%, #f7fffb 100%);

    --glass-bg: rgba(255, 255, 255, .72);
    --glass-border: rgba(255, 255, 255, .65);
}

/* Base */
html, body { height: 100%; }

body {
    font-family: var(--pc-font);
    background:
        radial-gradient(900px 480px at -10% -10%, rgba(37, 99, 235, .09), transparent 55%),
        radial-gradient(800px 420px at 110% 10%, rgba(16, 185, 129, .08), transparent 50%),
        var(--pc-bg);
    color: var(--pc-text);
    font-size: 1.04rem;
    font-weight: 500;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Colori utility */
.muted, .text-muted{ color: var(--pc-muted) !important; }
a{ color: var(--pc-brand); }
a:hover{ color: var(--pc-brand-2); }

/* Navbar */
.navbar {
    background: rgba(255, 255, 255, .86) !important;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(226, 232, 240, .9) !important;
}
.navbar.bg-white{
  background: rgba(255,255,255,.88) !important;
}
.navbar .navbar-brand{
  letter-spacing: .2px;
}

.navbar-brand img {
    filter: drop-shadow(0 6px 12px rgba(37, 99, 235, .12));
}

.navbar .nav-link{
  font-weight: 600;
  color: #374151;
}
.navbar .nav-link:hover{ color: var(--pc-text); }
.navbar .nav-link.active{
  color: var(--pc-brand) !important;
}

/* Buttons */
.btn{
  border-radius: 14px;
  font-weight: 700;
  letter-spacing: .2px;
}
.btn-primary {
    background: linear-gradient(135deg, var(--pc-brand), var(--pc-brand-2));
    border-color: transparent;
    box-shadow: 0 10px 22px rgba(37, 99, 235, .22);
}

.btn-primary:hover {
    filter: brightness(1.04);
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(37, 99, 235, .28);
}

.btn-outline-secondary,
.btn-outline-primary {
    background: rgba(255, 255, 255, .62);
}

.btn-outline-secondary:hover{
  background: #f9fafb;
  border-color: #d1d5db;
}

/* Forms */
.form-control, .form-select, .input-group-text{
  border-radius: 14px;
  border-color: var(--pc-border);
}
.form-control, .form-select{
  font-weight: 600;
}
.form-control:focus, .form-select:focus{
  border-color: rgba(37,99,235,.45);
  box-shadow: 0 0 0 .25rem rgba(37,99,235,.15);
}

.input-group-text,
.form-control,
.form-select {
    border-color: rgba(203, 213, 225, .95);
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(37, 99, 235, .55);
    box-shadow: 0 0 0 .25rem rgba(37, 99, 235, .12);
}

.table {
    --bs-table-bg: transparent;
}


/* Cards */

.card,
.bg-white.border.rounded-4,
.p-3.bg-white.border.rounded-3,
.p-2.bg-white.border.rounded-3 {
    background: var(--pc-card) !important;
    border: 1px solid var(--pc-border) !important;
    box-shadow: var(--pc-shadow-soft);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}


.card{
   
  border-radius: var(--pc-radius);
}

.card-hover {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.card-hover:hover {
    transform: translateY(-3px);
    box-shadow: var(--pc-shadow);
    border-color: rgba(37, 99, 235, .22) !important;
}


.shadow-sm{
  box-shadow: var(--pc-shadow) !important;
}
.card-header{
  border-bottom: 1px solid rgba(229,231,235,.75) !important;
  border-top-left-radius: var(--pc-radius) !important;
  border-top-right-radius: var(--pc-radius) !important;
}

/* Badges */
.badge{
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .2px;
}
.brand-badge {
    background: linear-gradient(135deg, rgba(37, 99, 235, .12), rgba(16, 185, 129, .12));
    color: #1e40af;
    border: 1px solid rgba(37, 99, 235, .18);
}

.tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .72rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(226, 232, 240, .95);
    color: #334155;
    font-size: .875rem;
    box-shadow: 0 8px 20px rgba(15, 23, 42, .045);
}

/* Breadcrumb */
.breadcrumb a{
  text-decoration: none;
  font-weight: 700;
}

/* Pills (tag selezionabili) */
.pill{
  border: 1px solid var(--pc-border);
  background: #fff;
  border-radius: 999px;
  padding: .45rem .85rem;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  user-select: none;
  transition: transform .08s ease, box-shadow .12s ease, border-color .12s ease;
}
.pill:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(17,24,39,.07);
}
.pill.active{
  border-color: rgba(37,99,235,.45);
  box-shadow: 0 0 0 .25rem rgba(37,99,235,.12);
}

/* Score box / Range */
.score-box{
  border: 1px solid rgba(229,231,235,.85);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  border-radius: var(--pc-radius);
}
.form-range::-webkit-slider-thumb{
  background: var(--pc-brand);
}
.form-range::-moz-range-thumb{
  background: var(--pc-brand);
}

/* Alerts */
.alert{
  border-radius: var(--pc-radius);
  border-color: rgba(229,231,235,.9);
}

/* Tabelle (landing “top ricercati”) */
.table{
  --bs-table-color: var(--pc-text);
}
.table thead.table-light th{
  background: #f8fafc !important;
  color: #374151;
  font-weight: 800;
}
.table td, .table th{
  padding-top: .85rem;
  padding-bottom: .85rem;
}

/* Sezioni hero (se riusato nella landing) */
.hero {
    position: relative;
    overflow: hidden;
    background: var(--header-bg);
    border-bottom: 1px solid rgba(226, 232, 240, .9);
}

.hero .shadow-sm {
    box-shadow: 0 18px 50px rgba(15, 23, 42, .10) !important;
}


.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.34) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.34) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.38), transparent 78%);
    pointer-events: none;
}

.hero::after {
    content: "";
    position: absolute;
    width: 340px;
    height: 340px;
    right: -120px;
    top: -120px;
    background: radial-gradient(circle, rgba(37, 99, 235, .18), transparent 68%);
    filter: blur(4px);
    pointer-events: none;
}

.hero > .container {
    position: relative;
    z-index: 1;
}

.table thead th {
    color: #475569;
    font-size: .86rem;
    text-transform: uppercase;
    letter-spacing: .02em;
}

footer {
    background: rgba(255, 255, 255, .78) !important;
    backdrop-filter: blur(10px);
}

/* Footer */
footer{
  color: #6b7280;
}

/* Spaziatura migliore su mobile */
@media (max-width: 576px){
  body{ font-size: 1.02rem; }
  .btn{ border-radius: 12px; }
  .card{ border-radius: 16px; }
}