:root{
  --pd-orange:#f97316;
  --pd-orange-2:#fb923c;
  --pd-black:#111111;
  --pd-white:#ffffff;
  --pd-brown:#7c4a21;
  --pd-cream:#fff7ed;
}

html[data-theme="dark"]{--bg:#0e1117;--panel:#151922;--surface:#1d2430;--border:#2b3442;--text:#f8fafc;--muted:#9ca3af;--accent:var(--pd-orange)}
html[data-theme="light"]{--bg:#f8fafc;--panel:#ffffff;--surface:#f1f5f9;--border:#e2e8f0;--text:#111827;--muted:#64748b;--accent:var(--pd-orange)}
html[data-theme="farm"]{--bg:#20150d;--panel:#2a1b10;--surface:#3a2617;--border:#5b3a20;--text:#fff7ed;--muted:#d6bda4;--accent:#f97316}

body{background:var(--bg)!important;color:var(--text)!important}
.porteira-shell{grid-template-columns:282px 1fr!important;background:var(--bg)}
.porteira-sidebar{background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,.08)),var(--panel)!important;border-right:1px solid var(--border)!important}
.porteira-brand-icon{background:linear-gradient(135deg,var(--pd-orange),var(--pd-brown))!important}
.porteira-nav a{display:flex;align-items:center;gap:8px;color:var(--text)!important;border:1px solid transparent}
.porteira-nav a.active,.porteira-nav a:hover{background:var(--surface)!important;border-color:var(--border)}
.porteira-main{background:var(--bg);min-width:0}
.porteira-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:18px 20px;margin-bottom:20px}
.top-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}
.theme-switcher{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px;gap:4px}
.theme-btn{border:0;background:transparent;color:var(--muted);padding:8px 12px;border-radius:999px;cursor:pointer;font-size:.86rem}
.theme-btn.active{background:var(--accent);color:white}
.top-user-menu{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:8px}
.top-user-avatar{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--pd-orange),var(--pd-brown));font-weight:800;color:white}
.top-user-meta{display:flex;flex-direction:column;line-height:1.1}.top-user-meta span{color:var(--muted);font-size:.78rem}.logout-top{padding:8px 10px!important}
.storage-side-card{margin-top:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:10px}.storage-side-head{display:flex;justify-content:space-between}.storage-side-bar{height:10px;background:rgba(0,0,0,.22);border-radius:999px;overflow:hidden}.storage-side-bar div{height:100%;background:linear-gradient(90deg,var(--pd-orange),var(--pd-orange-2));border-radius:999px}.storage-side-info{display:flex;flex-direction:column;gap:3px;color:var(--muted);font-size:.86rem}.storage-side-card small{color:var(--muted)}
.btn{background:var(--surface)!important;border:1px solid var(--border)!important;color:var(--text)!important}.btn.primary{background:linear-gradient(135deg,var(--pd-orange),var(--pd-brown))!important;color:#fff!important;border:0!important}
.drive-page{display:flex;flex-direction:column;gap:18px}.drive-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;background:linear-gradient(135deg,rgba(249,115,22,.22),rgba(124,74,33,.10)),var(--panel);border:1px solid var(--border);border-radius:24px;padding:22px}.drive-hero h2{margin:8px 0 6px;font-size:2rem}.drive-hero p{margin:0;color:var(--muted)}.breadcrumbs{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:.9rem}.breadcrumbs a{text-decoration:none;color:var(--accent);font-weight:700}.drive-actions-main{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.drive-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.drive-stat-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:16px}.drive-stat-card span{display:block;color:var(--muted);font-size:.86rem;margin-bottom:8px}.drive-stat-card strong{font-size:1.7rem}
.drive-search{display:flex;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:12px}.drive-search input{flex:1;background:var(--surface)!important;color:var(--text)!important;border:1px solid var(--border)!important}
.drive-section{background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:18px}.drive-section-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px}.drive-section-head h3{margin:0}.drive-section-head span{color:var(--muted)}.drive-empty{border:1px dashed var(--border);border-radius:18px;padding:24px;text-align:center;color:var(--muted);background:var(--surface)}
.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}.folder-card{display:flex;gap:12px;align-items:center;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px;transition:.15s}.folder-card:hover,.folder-card.drag-over{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 12px 30px rgba(249,115,22,.15)}.folder-icon{font-size:2rem}.folder-info{display:flex;flex-direction:column;gap:4px}.folder-info span{color:var(--muted);font-size:.86rem}.loose-drop{border:1px dashed var(--border);background:var(--surface);border-radius:18px;padding:14px;text-align:center;color:var(--muted)}.loose-drop.drag-over{border-color:var(--accent);color:var(--accent)}
.drive-files.is-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}.drive-file-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;color:var(--text);transition:.15s}.drive-file-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 14px 30px rgba(0,0,0,.16)}.drive-file-preview{height:165px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.22);text-decoration:none;color:var(--text);position:relative}.drive-file-preview img,.drive-file-preview video{width:100%;height:100%;object-fit:cover;display:block}.video-badge{position:absolute;right:10px;bottom:10px;background:rgba(0,0,0,.64);color:#fff;border-radius:999px;padding:6px 9px}.generic-file{font-size:3rem}.drive-file-body{padding:12px;padding-right:44px;display:flex;flex-direction:column;gap:4px}.drive-file-mainline{display:flex;gap:6px;align-items:center}.drive-file-body strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drive-file-body span,.drive-file-body small{color:var(--muted);font-size:.82rem}.favorite-mark{font-size:.9rem}.file-kebab{position:absolute;right:8px;bottom:12px;width:34px;height:34px;border-radius:12px;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;font-size:1.2rem}
.drive-files.is-list{display:flex;flex-direction:column;gap:10px}.drive-files.is-list .drive-file-card{display:grid;grid-template-columns:86px 1fr 48px;align-items:center;min-height:82px}.drive-files.is-list .drive-file-preview{height:82px}.drive-files.is-list .drive-file-body{padding:12px}.drive-files.is-list .file-kebab{position:static;justify-self:center}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:22px}.modal-overlay[hidden]{display:none}.modal-card{width:min(480px,100%);background:var(--panel);border:1px solid var(--border);border-radius:22px;box-shadow:0 24px 80px rgba(0,0,0,.35);padding:20px}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.modal-head h3{margin:0}.modal-close{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.context-menu{position:absolute;z-index:10000;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 60px rgba(0,0,0,.35);padding:6px;min-width:210px}.context-menu[hidden]{display:none}.context-menu button{display:block;width:100%;text-align:left;background:transparent;color:var(--text);border:0;padding:10px 12px;border-radius:10px;cursor:pointer}.context-menu button:hover{background:var(--surface)}.context-menu .danger{color:#ef4444}.toast{position:fixed;right:22px;bottom:22px;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:14px 16px;border-radius:14px;z-index:10001;box-shadow:0 18px 50px rgba(0,0,0,.25)}.toast.success{border-color:#22c55e}.toast.error{border-color:#ef4444}.toast[hidden]{display:none}.upload-summary{display:none;margin-top:14px;padding:12px 14px;border-radius:12px;white-space:pre-wrap}.upload-summary.info{display:block;background:#11243b;border:1px solid #244368;color:#d7e5ff}.upload-summary.success{display:block;background:#10281d;border:1px solid #1f5935}.upload-summary.error{display:block;background:#32131b;border:1px solid #6b2233}
@media(max-width:1100px){.porteira-shell{grid-template-columns:1fr!important}.porteira-sidebar{display:flex!important}.drive-stats-row{grid-template-columns:1fr 1fr}.porteira-topbar,.drive-hero{flex-direction:column}.top-actions{justify-content:flex-start}.storage-side-card{margin-top:18px}}
@media(max-width:680px){.drive-stats-row{grid-template-columns:1fr}.drive-search{flex-direction:column}.drive-files.is-list .drive-file-card{grid-template-columns:70px 1fr 42px}.theme-switcher{width:100%;justify-content:center}.top-user-menu{width:100%}.top-user-meta{flex:1}}
