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

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

:root{
    --bg-0:#0a0e17;
    --bg-1:#0f1522;
    --bg-2:#151d2e;
    --bg-3:#1c2739;
    --bg-4:#26344b;
    --border:#243049;
    --border-hover:#3a4d70;
    --text:#eef2fb;
    --text-light:#aeb9cf;
    --text-muted:#6f7d98;
    --primary:#e0a92e;
    --primary-light:#f4c651;
    --primary-dark:#c08e1f;
    --primary-glow:rgba(224,169,46,.30);
    --info:#4aa8d8;
    --success:#35c76a;
    --success-bg:rgba(53,199,106,.14);
    --warning:#e0a92e;
    --danger:#e35b46;
    --danger-bg:rgba(227,91,70,.14);
    --water:#4aa8d8;
    --gas:#e0803a;
    --electric:#e3c341;
    --break:#c56bd6;
    --font-display:'Big Shoulders Display','Inter',sans-serif;
    --radius:14px;
    --radius-sm:9px;
    --radius-lg:20px;
    --shadow:0 8px 30px rgba(0,0,0,.35);
    --shadow-lg:0 20px 60px rgba(0,0,0,.5);
    --tr:.22s cubic-bezier(.4,0,.2,1);
}

html{scroll-behavior:smooth;}
body{
    font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    background:
        radial-gradient(1200px 600px at 80% -10%, rgba(224,169,46,.08), transparent 60%),
        radial-gradient(1000px 500px at -10% 20%, rgba(74,168,216,.06), transparent 55%),
        var(--bg-0);
    color:var(--text);
    line-height:1.6;
    font-size:15px;
    min-height:100vh;
    -webkit-font-smoothing:antialiased;
}
a{color:var(--primary-light);text-decoration:none;transition:var(--tr);}
a:hover{color:var(--primary);}
::selection{background:var(--primary);color:#0a0e17;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-track{background:var(--bg-1);}
::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:5px;}
::-webkit-scrollbar-thumb:hover{background:var(--primary-dark);}

h1,h2,h3{font-family:var(--font-display);letter-spacing:.4px;line-height:1.1;font-weight:800;}
h1{font-size:2.1rem;}
h2{font-size:1.5rem;}
h3{font-size:1.15rem;}

/* ===== NAVBAR ===== */
.navbar{
    position:sticky;top:0;z-index:900;
    display:flex;align-items:center;gap:20px;
    height:64px;padding:0 26px;
    background:rgba(10,14,23,.82);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid var(--border);
}
.nav-left{display:flex;align-items:center;gap:12px;}
.nav-brand{display:flex;align-items:center;gap:10px;color:var(--text);font-weight:800;}
.nav-brand:hover{color:var(--text);}
.brand-mark{color:var(--primary);font-size:1.1rem;filter:drop-shadow(0 0 10px var(--primary-glow));}
.brand-text{font-family:var(--font-display);font-size:1.2rem;text-transform:uppercase;letter-spacing:1px;}
.nav-links{list-style:none;display:flex;gap:2px;margin-left:8px;flex:1;}
.nav-links a{
    display:block;padding:8px 14px;border-radius:var(--radius-sm);
    color:var(--text-light);font-size:.9rem;font-weight:500;
}
.nav-links a:hover{background:rgba(255,255,255,.05);color:var(--text);}
.nav-links a.active{color:var(--primary);background:rgba(224,169,46,.10);}
.nav-right{display:flex;align-items:center;gap:14px;margin-left:auto;}

.lang-switch{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:999px;padding:3px;gap:2px;}
.lang-opt{
    padding:4px 11px;border-radius:999px;font-size:.78rem;font-weight:700;
    color:var(--text-muted);letter-spacing:.5px;
}
.lang-opt:hover{color:var(--text);}
.lang-opt.active{background:var(--gradient,linear-gradient(135deg,var(--primary-dark),var(--primary)));color:#0a0e17;box-shadow:0 2px 10px var(--primary-glow);}

.user-chip{display:flex;align-items:center;gap:9px;padding:5px 6px 5px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:999px;}
.user-name{font-weight:600;font-size:.85rem;}
.user-role{font-size:.7rem;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-weight:700;}
.nav-burger{display:none;background:none;border:1px solid var(--border);color:var(--text);font-size:1.2rem;padding:5px 11px;border-radius:8px;cursor:pointer;}

/* ===== LAYOUT ===== */
.container{max-width:1120px;margin:0 auto;padding:34px 22px 60px;}
.container-wide{max-width:1320px;}
.shell{display:grid;grid-template-columns:248px 1fr;min-height:calc(100vh - 64px);}
.sidebar{
    border-right:1px solid var(--border);
    background:linear-gradient(180deg,var(--bg-1),var(--bg-0));
    padding:20px 14px;display:flex;flex-direction:column;gap:3px;
}
.side-link{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:var(--radius-sm);color:var(--text-light);font-weight:500;font-size:.92rem;}
.side-link:hover{background:rgba(255,255,255,.04);color:var(--text);}
.side-link.active{background:rgba(224,169,46,.12);color:var(--primary);box-shadow:inset 3px 0 0 var(--primary);}
.side-icon{width:20px;text-align:center;font-size:1.05rem;}
.side-divider{font-size:.7rem;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:16px 13px 6px;font-weight:700;}
.content{padding:30px 34px 60px;min-width:0;}

/* ===== CARD ===== */
.card{background:linear-gradient(160deg,var(--bg-2),var(--bg-1));border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:22px;}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap;}
.card-head h1,.card-head h2{margin:0;}
.card-sub{color:var(--text-light);margin-bottom:18px;}
.card.flush{padding:0;overflow:hidden;}

/* ===== BUTTONS ===== */
.btn{
    display:inline-flex;align-items:center;gap:7px;cursor:pointer;
    padding:10px 18px;border-radius:var(--radius-sm);border:1px solid transparent;
    font-family:inherit;font-size:.9rem;font-weight:600;line-height:1;
    transition:var(--tr);text-decoration:none;white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#0a0e17;box-shadow:0 4px 16px var(--primary-glow);}
.btn-primary:hover{color:#0a0e17;filter:brightness(1.07);box-shadow:0 6px 22px var(--primary-glow);}
.btn-ghost{background:var(--bg-2);border-color:var(--border);color:var(--text-light);}
.btn-ghost:hover{border-color:var(--border-hover);color:var(--text);}
.btn-danger{background:var(--danger-bg);border-color:rgba(227,91,70,.4);color:var(--danger);}
.btn-danger:hover{background:var(--danger);color:#fff;}
.btn-success{background:var(--success-bg);border-color:rgba(53,199,106,.4);color:var(--success);}
.btn-success:hover{background:var(--success);color:#04220f;}
.btn-sm{padding:7px 13px;font-size:.82rem;}
.btn-xs{padding:5px 10px;font-size:.75rem;border-radius:7px;}
.btn-block{width:100%;justify-content:center;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}

/* ===== FORMS ===== */
.form-group{margin-bottom:16px;}
.form-group label{display:block;margin-bottom:6px;font-size:.85rem;font-weight:600;color:var(--text-light);}
.req{color:var(--danger);}
.hint{font-size:.78rem;color:var(--text-muted);margin-top:5px;}
input[type=text],input[type=password],input[type=email],input[type=tel],input[type=number],input[type=date],input[type=time],input[type=datetime-local],select,textarea{
    width:100%;padding:11px 13px;background:var(--bg-0);border:1px solid var(--border);border-radius:var(--radius-sm);
    color:var(--text);font-family:inherit;font-size:.92rem;transition:var(--tr);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);}
textarea{resize:vertical;min-height:110px;}
select{cursor:pointer;}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;}
.checkbox-row{display:flex;align-items:center;gap:9px;}
.checkbox-row input{width:auto;}

/* ===== TABLE ===== */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);}
table{width:100%;border-collapse:collapse;font-size:.9rem;}
thead th{background:var(--bg-3);text-align:left;padding:13px 15px;font-size:.76rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:700;white-space:nowrap;}
tbody td{padding:13px 15px;border-top:1px solid var(--border);vertical-align:middle;}
tbody tr{transition:var(--tr);}
tbody tr:hover{background:rgba(255,255,255,.025);}
.t-ref{font-family:var(--font-display);font-weight:700;color:var(--primary);letter-spacing:.5px;}
.t-muted{color:var(--text-muted);}
.row-click{cursor:pointer;}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.3px;text-transform:uppercase;}
.status-open{background:var(--bg-4);color:var(--text-light);}
.status-progress{background:rgba(224,169,46,.16);color:var(--primary-light);}
.status-done{background:var(--success-bg);color:var(--success);}
.cat-chip{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.85rem;}
.cat-dot{width:9px;height:9px;border-radius:50%;display:inline-block;}
.cat-water .cat-dot,.dot-water{background:var(--water);}
.cat-gas .cat-dot,.dot-gas{background:var(--gas);}
.cat-electric .cat-dot,.dot-electric{background:var(--electric);}
.cat-break .cat-dot,.dot-break{background:var(--break);}
.cat-broken .cat-dot,.dot-broken{background:var(--danger);}
.cat-other .cat-dot,.dot-other{background:var(--text-muted);}
.pstate{display:inline-flex;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:700;}
.pstate-good{background:var(--success-bg);color:var(--success);}
.pstate-medium{background:rgba(224,169,46,.16);color:var(--primary-light);}
.pstate-bad{background:var(--danger-bg);color:var(--danger);}

/* ===== STAT CARDS ===== */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;}
.stat-card{background:linear-gradient(160deg,var(--bg-2),var(--bg-1));border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;inset:0 auto 0 0;width:4px;background:var(--primary);}
.stat-number{font-family:var(--font-display);font-size:2.3rem;font-weight:800;line-height:1;color:var(--text);}
.stat-label{color:var(--text-muted);font-size:.82rem;margin-top:6px;text-transform:uppercase;letter-spacing:.5px;}
.stat-card.accent .stat-number{color:var(--primary);}
.stat-card.good::before{background:var(--success);}
.stat-card.bad::before{background:var(--danger);}

/* ===== TABS ===== */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;flex-wrap:wrap;}
.tabs a{padding:10px 16px;color:var(--text-light);font-weight:600;font-size:.88rem;border-bottom:2px solid transparent;margin-bottom:-1px;}
.tabs a:hover{color:var(--text);}
.tabs a.active{color:var(--primary);border-bottom-color:var(--primary);}

/* ===== ALERTS ===== */
.alert{padding:13px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.9rem;border:1px solid transparent;}
.alert-success{background:var(--success-bg);border-color:rgba(53,199,106,.35);color:var(--success);}
.alert-error,.alert-danger{background:var(--danger-bg);border-color:rgba(227,91,70,.35);color:var(--danger);}
.alert-info{background:rgba(74,168,216,.12);border-color:rgba(74,168,216,.35);color:var(--info);}
.alert-warning{background:rgba(224,169,46,.12);border-color:rgba(224,169,46,.35);color:var(--primary-light);}

/* ===== TOGGLE (Discord-stílus) ===== */
.toggle{position:relative;display:inline-block;width:44px;height:24px;flex:none;}
.toggle input{opacity:0;width:0;height:0;}
.toggle .track{position:absolute;inset:0;background:var(--bg-4);border-radius:999px;transition:var(--tr);cursor:pointer;}
.toggle .track::before{content:'';position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:var(--tr);}
.toggle input:checked + .track{background:var(--success);}
.toggle input:checked + .track::before{transform:translateX(20px);}
.toggle input:disabled + .track{opacity:.5;cursor:not-allowed;}

.perm-group{margin-bottom:22px;}
.perm-group h3{color:var(--primary);font-size:.8rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;border-bottom:1px solid var(--border);padding-bottom:8px;}
.perm-row{display:flex;align-items:center;justify-content:space-between;padding:9px 4px;border-bottom:1px solid rgba(36,48,73,.5);}
.perm-row:last-child{border-bottom:none;}
.perm-label{font-size:.92rem;color:var(--text-light);}

/* ===== ROLE LIST ===== */
.role-list{display:flex;flex-direction:column;gap:4px;}
.role-item{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:var(--tr);}
.role-item:hover{background:rgba(255,255,255,.04);}
.role-item.active{background:var(--bg-3);border-color:var(--border-hover);}
.role-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);}
.role-name{font-weight:600;}

/* ===== HERO / CÉGES ===== */
.hero{position:relative;text-align:center;padding:90px 30px;border-radius:var(--radius-lg);border:1px solid var(--border);background:linear-gradient(160deg,var(--bg-2),var(--bg-0));overflow:hidden;margin-bottom:34px;}
.hero::after{content:'';position:absolute;width:520px;height:520px;top:-260px;left:50%;transform:translateX(-50%);background:radial-gradient(circle,var(--primary-glow),transparent 70%);pointer-events:none;}
.hero h1{font-size:3rem;margin-bottom:16px;position:relative;}
.hero p{font-size:1.15rem;color:var(--text-light);max-width:640px;margin:0 auto 26px;position:relative;}
.hero .btn{position:relative;margin:0 5px;}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:34px;}
.feature-card{background:linear-gradient(160deg,var(--bg-2),var(--bg-1));border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;transition:var(--tr);}
.feature-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.feature-icon{font-size:2rem;margin-bottom:14px;}
.feature-card h3{margin-bottom:9px;}
.feature-card p{color:var(--text-light);font-size:.94rem;}
.section-title{text-align:center;margin-bottom:26px;}
.section-title h2{font-size:2rem;}

/* ===== AUTH ===== */
.auth-wrap{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:40px 20px;}
.auth-box{width:100%;max-width:400px;}
.auth-box .card{padding:34px;}
.auth-box h1{text-align:center;margin-bottom:6px;}
.auth-box .sub{text-align:center;color:var(--text-muted);margin-bottom:24px;font-size:.88rem;}

/* ===== CALENDAR ===== */
.cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap;}
.cal-title{font-family:var(--font-display);font-size:1.3rem;}
.cal-grid{display:grid;grid-template-columns:64px repeat(7,1fr);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-1);min-width:820px;}
.cal-head{background:var(--bg-3);padding:10px 8px;text-align:center;font-size:.8rem;font-weight:700;border-bottom:1px solid var(--border);border-left:1px solid var(--border);}
.cal-head small{display:block;color:var(--text-muted);font-weight:500;}
.cal-corner{background:var(--bg-3);border-bottom:1px solid var(--border);}
.cal-hour{padding:6px 8px;font-size:.72rem;color:var(--text-muted);text-align:right;border-top:1px solid var(--border);height:56px;}
.cal-cell{border-top:1px solid var(--border);border-left:1px solid var(--border);height:56px;position:relative;padding:2px;}
.cal-event{position:absolute;left:2px;right:2px;border-radius:6px;padding:3px 6px;font-size:.72rem;line-height:1.25;overflow:hidden;color:#0a0e17;font-weight:600;box-shadow:0 2px 6px rgba(0,0,0,.3);z-index:2;}
.cal-event.conflict{outline:2px solid var(--danger);}
.cal-event small{display:block;font-weight:500;opacity:.85;}
.cal-scroll{overflow-x:auto;}

/* rows (per-property weekly overview) */
.grid-week{display:grid;grid-template-columns:150px repeat(7,1fr);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;min-width:900px;}
.gw-head{background:var(--bg-3);padding:10px;font-size:.78rem;font-weight:700;text-align:center;border-left:1px solid var(--border);border-bottom:1px solid var(--border);}
.gw-prop{padding:12px 10px;font-weight:600;font-size:.86rem;border-top:1px solid var(--border);background:var(--bg-2);display:flex;align-items:center;}
.gw-cell{border-top:1px solid var(--border);border-left:1px solid var(--border);padding:6px;min-height:66px;display:flex;flex-direction:column;gap:4px;}
.gw-chip{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#0a0e17;border-radius:6px;padding:4px 7px;font-size:.74rem;font-weight:600;}
.gw-chip.conflict{background:var(--danger);color:#fff;}
.gw-chip small{display:block;font-weight:500;opacity:.9;}

/* ===== MISC ===== */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);}
.empty-icon{font-size:3rem;margin-bottom:14px;opacity:.6;}
.thumb-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;}
.thumb{width:84px;height:84px;border-radius:10px;object-fit:cover;border:1px solid var(--border);}
.timeline{position:relative;padding-left:22px;}
.timeline::before{content:'';position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--border);}
.tl-item{position:relative;padding:0 0 16px 4px;}
.tl-item::before{content:'';position:absolute;left:-20px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px var(--bg-1);}
.tl-time{font-size:.76rem;color:var(--text-muted);}
.tl-body{font-size:.92rem;margin-top:2px;}
.tl-actor{color:var(--primary-light);font-weight:600;}
.pill{display:inline-block;padding:2px 9px;border-radius:999px;background:var(--bg-3);font-size:.75rem;color:var(--text-light);}
.detail-list{list-style:none;}
.detail-list li{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.9rem;}
.detail-list li:last-child{border-bottom:none;}
.detail-list .k{color:var(--text-muted);}
.detail-list .v{font-weight:600;text-align:right;}
.split{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:start;}
.split-left{display:grid;grid-template-columns:260px 1fr;gap:22px;align-items:start;}
.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:22px;align-items:start;}
.mt{margin-top:18px;}
.mb0{margin-bottom:0;}
.text-muted{color:var(--text-muted);}
.text-c{text-align:center;}
.flex{display:flex;gap:10px;align-items:center;}
.flex-between{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.gap-wrap{display:flex;gap:10px;flex-wrap:wrap;}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
    .nav-links{position:fixed;top:64px;left:0;right:0;flex-direction:column;background:var(--bg-1);border-bottom:1px solid var(--border);padding:10px;display:none;}
    body.nav-open .nav-links{display:flex;}
    .nav-burger{display:block;}
    .shell{grid-template-columns:1fr;}
    .sidebar{position:fixed;top:64px;bottom:0;left:0;width:248px;z-index:800;transform:translateX(-100%);transition:var(--tr);}
    body.nav-open .sidebar{transform:none;}
    .content{padding:22px 18px 50px;}
    .split,.split-left,.two-col,.grid-2{grid-template-columns:1fr;}
    .hero h1{font-size:2.2rem;}
    .user-name{display:none;}
}
