12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830 |
- $high-priority-color: hsl(360, 71%, 60%);
- $low-priority-color: hsl(200, 68%, 73%);
- $minWidth: 1024px;
- $sidebarWidth: 280px;
- $desktopSidebarWidth: 360px;
- $navigationWidth: 260px;
- $mobileNavigationWidth: 50px;
- $mobileNavigationWidthOpen: 220px;
- :root {
- --button-action-color: hsl(0, 0%, 60%);
- --button-background: white;
- --button-background-active: hsl(0, 0, 98%);
- --button-active: hsl(204, 7%, 28%);
- --button-active-active: hsla(0, 0%, 0%, 0.55);
- --button-primary-text: var(--text-inverted);
- --button-primary-background: hsl(203, 65%, 55%);
- --button-primary-background-active: hsl(203, 65%, 45%);
- --header-primary: hsl(202, 8%, 28%);
- --header-secondary: hsl(198, 10%, 69%);
- --text-normal: hsl(60, 1%, 34%);
- --text-muted: hsl(213, 3%, 64%);
- --text-muted-highlight: hsl(205, 90%, 90%);
- --text-muted-alt: hsl(197, 16%, 65%);
- --text-link: hsl(204, 72%, 50%);
- --text-inverted: white;
- --text-active: white;
- --text-nav: hsl(204, 72%, 50%);
- --text-button-primary: var(--button-primary-background);
- --text-button-primary-active: var(--button-primary-background-active);
- --text-button-secondary: var(--interactive-muted);
- --nav-icon: hsl(0, 0%, 50%);
- --highlight: hsl(205, 90%, 60%);
- --interactive-primary: black;
- --interactive-muted: hsl(210, 3%, 71%);
- --interactive-muted-active: hsl(210, 4%, 71%);
- --interactive-muted-alt: hsl(197, 19%, 78%);
- --interactive-muted-alt-selected: hsl(206, 7%, 37%);
- --background-primary: hsl(210, 17%, 98%);
- --background-primary-alt: hsl(197, 16%, 94%);
- --background-secondary: white;
- --background-secondary-hover: hsl(239, 4%, 95%);
- --background-tertiary: hsl(233, 9%, 19%);
- --background-quaternary: hsl(231, 9%, 16%);
- --background-quaternary-alt: hsl(228, 17%, 91%);
- --background-popover: white;
- --background-active: hsl(233, 9%, 19%);
- --background-highlight: hsl(200, 100%, 91%);
- --background-article-meta: hsl(212, 14%, 99%);
- --background-article-customer: hsl(201, 46%, 93%);
- --background-article-customer-meta: hsl(201, 43%, 96%);
- --background-modifier-accent: hsla(0, 0%, 0%, 0.04);
- --background-modifier-accent-light: hsla(0, 0%, 0%, 0.02);
- --background-modifier-accent-dark: hsla(0, 0%, 0%, 0.3);
- --background-modifier-lighter: hsla(0, 0%, 100%, 0.06);
- --background-modifier-border: hsla(0, 0%, 0%, 0.1);
- --background-modifier-hover: hsla(240, 3%, 50%, 0.1);
- --backdrop-clue-start: hsla(202, 68%, 54%, 0.1);
- --backdrop-clue-end: hsla(202, 68%, 54%, 0.9);
- --border: hsl(0, 0%, 90%);
- --border-alt: hsl(198, 18%, 86%);
- --border-highlight: hsl(200, 71%, 59%);
- --border-internal: hsl(18, 91%, 89%);
- --border-internal-stripe: hsl(18, 94%, 95%);
- --border-article-customer: hsl(199, 38%, 90%);
- --border-article-customer-selected: hsl(199, 44%, 85%);
- --shadow-highlight: hsl(201, 62%, 90%);
- --supergood-color: hsl(145, 51%, 45%);
- --good-color: hsl(62, 45%, 46%);
- --ok-color: hsl(41, 100%, 49%);
- --bad-color: hsl(30, 93%, 50%);
- --superbad-color: hsl(19, 90%, 51%);
- --ghost-color: hsl(0, 0%, 74%);
- --danger-color: hsl(0, 65%, 55%);
- --pending-color: hsl(206, 7%, 28%);
- --elevation-stroke: 0 1px hsl(210, 7%, 94%);
- --elevation-low: 0 1px 5px hsla(205, 30%, 30%, 0.1);
- --elevation-high: 0 1px 14px hsla(208, 95%, 3%, 0.25);
- --highlighter-yellow: hsl(48, 81%, 82%);
- --highlighter-green: hsl(105, 54%, 80%);
- --highlighter-blue: hsl(207, 92%, 85%);
- --highlighter-pink: hsl(338, 90%, 82%);
- --highlighter-purple: hsl(288, 62%, 86%);
- --file-icon-background: white;
- --file-icon-color: hsl(198, 18%, 86%);
- --tag-text: hsl(198, 5%, 41%);
- --tag-background: hsl(198, 19%, 92%);
- --fullscreen-background: var(--background-tertiary);
- --fullscreen-text: var(--text-muted);
- --fullscreen-text-link: var(--text-inverted);
- --fullscreen-text-muted: hsl(233, 7%, 26%);
- --fullscreen-drop-shadow: 0 8px 17px 0 rgba(0, 0, 0, 0.2),
- 0 6px 20px 0 rgba(0, 0, 0, 0.19);
- --menu-text: hsl(0, 0%, 74%);
- --menu-text-active: white;
- --menu-text-open: white;
- --menu-text-closed: white;
- --menu-text-escalating: white;
- --menu-background-active: var(--button-primary-background);
- --menu-icon: hsl(206, 5%, 42%);
- --menu-icon-secondary: hsl(0, 0%, 30%);
- --menu-icon-secondary-hover-background: var(--text-inverted);
- --menu-switch-background: hsl(0, 0%, 5%);
- --menu-switch-pointer: var(--background-tertiary);
- --menu-switch-pointer-active: var(--menu-text-active);
- --menu-background-primary: var(--background-quaternary);
- --menu-background-primary-hover: hsla(0, 0%, 0%, 0.3);
- --menu-background-secondary: var(--background-tertiary);
- --menu-close-tab-background: var(--background-tertiary);
- --menu-close-tab-opacity: 0.3;
- --menu-border: none;
- --menu-border-secondary: none;
- }
- // dark mode
- [data-theme='dark'] {
- --button-action-color: hsl(0, 0%, 80%);
- --button-background: hsla(0, 0%, 100%, 0.03);
- --button-background-active: hsla(0, 0%, 100%, 0.015);
- --button-active: hsla(0, 0%, 100%, 0.1);
- --button-active-active: hsla(0, 0%, 100%, 0.08);
- --header-primary: white;
- --header-secondary: hsl(198, 5%, 73%);
- --text-normal: hsl(205, 1%, 86%);
- --text-muted: hsl(213, 3%, 60%);
- --text-muted-alt: hsl(213, 8%, 61%);
- --text-link: hsl(202, 72%, 50%);
- --text-nav: hsl(205, 1%, 84%);
- --nav-icon: hsl(0, 0%, 50%);
- --highlight: hsl(205, 90%, 60%);
- --interactive-primary: white;
- --interactive-muted: hsl(213, 3%, 64%);
- --interactive-muted-active: hsl(213, 3%, 35%);
- --interactive-muted-alt: hsl(209, 5%, 35%);
- --interactive-muted-alt-selected: hsl(205, 4%, 75%);
- --background-primary: hsl(230, 5%, 19%);
- --background-primary-alt: hsl(230, 5%, 21%);
- --background-secondary: hsl(230, 5%, 23%);
- --background-secondary-hover: hsl(230, 5%, 20%);
- --background-tertiary: hsl(230, 7%, 17%);
- --background-quaternary: hsl(230, 7%, 13%);
- --background-quaternary-alt: hsl(230, 4%, 30%);
- --background-popover: hsl(216, 3%, 30%);
- --background-active: var(--highlight);
- --background-highlight: hsl(205, 30%, 27%);
- --background-article-meta: hsl(230, 7%, 25%);
- --background-article-customer: hsl(218, 8%, 32%);
- --background-article-customer-meta: hsl(218, 6%, 30%);
- --background-modifier-accent: hsla(0, 0%, 0%, 0.12);
- --background-modifier-accent-light: hsla(0, 0%, 0%, 0.06);
- --background-modifier-accent-dark: hsla(0, 0%, 0%, 0.3);
- --background-modifier-lighter: hsla(0, 0%, 100%, 0.08);
- --background-modifier-border: hsla(0, 0%, 0%, 0.17);
- --background-modifier-hover: hsla(230, 5%, 36%, 0.4);
- --backdrop-clue-start: hsla(202, 68%, 54%, 0.1);
- --backdrop-clue-end: hsla(202, 68%, 54%, 0.9);
- --border: hsl(230, 4%, 17%);
- --border-alt: hsl(230, 7%, 18%);
- --border-highlight: hsl(205, 70%, 50%);
- --border-internal: hsl(18, 30%, 39%);
- --border-internal-stripe: hsl(18, 30%, 30%);
- --border-article-customer: hsl(209, 6%, 30%);
- --border-article-customer-selected: hsl(199, 10%, 33%);
- --shadow-highlight: hsl(205, 42%, 36%);
- --supergood-color: hsl(145, 51%, 45%);
- --good-color: hsl(62, 45%, 46%);
- --ok-color: hsl(41, 100%, 49%);
- --bad-color: hsl(30, 93%, 50%);
- --superbad-color: hsl(19, 90%, 51%);
- --ghost-color: hsl(0, 0%, 50%);
- --danger-color: hsl(0, 82%, 59%);
- --pending-color: hsl(205, 1%, 44%);
- --elevation-stroke: 0 1px hsla(0, 0%, 0%, 0.13);
- --elevation-low: 0 1px 5px hsla(0, 0%, 0%, 0.15);
- --elevation-high: 0 1px 14px hsla(0, 0%, 0%, 0.25);
- --highlighter-yellow: hsl(48, 34%, 30%);
- --highlighter-green: hsl(105, 34%, 27%);
- --highlighter-blue: hsl(207, 41%, 30%);
- --highlighter-pink: hsl(338, 28%, 30%);
- --highlighter-purple: hsl(288, 22%, 36%);
- --file-icon-background: hsl(216, 5%, 77%);
- --file-icon-color: hsl(230, 7%, 21%);
- --tag-text: var(--text-normal);
- --tag-background: hsl(230, 5%, 32%);
- }
- @mixin dark {
- [data-theme='dark'] & {
- @content;
- }
- }
- @mixin desktop {
- @media screen and (min-width: 1260px) {
- @content;
- }
- }
- @mixin small-desktop {
- @media screen and (max-width: 1260px) {
- @content;
- }
- }
- @mixin tablet {
- @media screen and (min-width: 768px) {
- @content;
- }
- }
- @mixin phone {
- #app.navigation-collapsed & {
- @content;
- }
- @media screen and (max-width: 767px) {
- @content;
- }
- }
- /* sets LTR and RTL within the same style call */
- @mixin bidi-style($prop, $value, $inverse-prop, $default-value) {
- #{$prop}: $value;
- html[dir='rtl'] & {
- #{$inverse-prop}: $value;
- #{$prop}: $default-value;
- }
- }
- /* adds a property only in RTL */
- @mixin rtl($prop, $value) {
- html[dir='rtl'] & {
- #{$prop}: $value;
- }
- }
- /* adds a property only in LTR */
- @mixin ltr($prop, $value) {
- html[dir='ltr'] & {
- #{$prop}: $value;
- }
- }
- %clickable {
- cursor: pointer;
- user-select: none;
- touch-action: manipulation;
- }
- html {
- height: 100%;
- }
- body {
- font-family: 'Fira Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
- font-weight: normal;
- font-variant-ligatures: none;
- line-height: 1.45;
- background: var(--background-primary);
- height: 100%;
- color: var(--text-normal);
- word-wrap: break-word;
- overflow-wrap: break-word;
- display: flex;
- flex-direction: column;
- }
- /* prevent clickable <use xlink:href="#icon-abc"></use> */
- use {
- pointer-events: none;
- }
- p {
- margin: 12px 0;
- &.subtle {
- color: var(--text-muted);
- }
- &.description {
- color: var(--text-muted);
- }
- }
- h3 + .description {
- margin-top: 0;
- }
- strong {
- font-weight: 500;
- }
- hr {
- border-top-color: var(--background-modifier-border);
- }
- .inherit-color {
- color: inherit;
- }
- .text-muted {
- color: var(--text-muted);
- }
- .text-placeholder {
- color: var(--interactive-muted);
- }
- .text-small {
- font-size: 12px;
- }
- .u-highlight {
- color: var(--text-link);
- }
- .u-dontfold {
- flex-shrink: 0;
- }
- .u-invisible {
- opacity: 0;
- pointer-events: none;
- position: absolute !important;
- }
- [data-dir='ltr'] {
- direction: ltr;
- }
- [data-dir='rtl'] {
- direction: rtl;
- }
- a {
- outline: none !important;
- @extend .u-highlight;
- &.is-disabled,
- &[disabled] {
- pointer-events: none;
- cursor: not-allowed !important;
- opacity: 0.33;
- }
- }
- a.create {
- color: hsl(145, 51%, 45%);
- text-decoration: underline;
- }
- small {
- color: var(--text-muted);
- font-size: 12px;
- }
- blockquote {
- font-size: inherit;
- }
- ol,
- ul {
- padding-inline-start: 20px;
- }
- #app {
- display: flex;
- flex: 1;
- min-width: $minWidth;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- @include phone {
- min-width: auto;
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- }
- }
- .u-unclickable {
- pointer-events: none;
- }
- .u-clickable {
- @extend %clickable;
- }
- .u-unselectable {
- pointer-events: none;
- user-select: none;
- }
- .u-no-userselect {
- user-select: none;
- }
- .u-textTruncate {
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .u-positionOrigin {
- position: relative;
- }
- .u-inlineBlock {
- display: inline-block;
- }
- .u-inlinePad {
- margin: 0 5px;
- }
- .u-notAllowed {
- cursor: not-allowed;
- }
- .u-overflow-wrap {
- word-break: break-word;
- @supports (overflow-wrap: anywhere) {
- overflow-wrap: anywhere;
- word-break: unset;
- }
- }
- .u-breakNormal.u-breakNormal {
- word-break: normal;
- @supports (overflow-wrap: normal) {
- overflow-wrap: normal;
- }
- }
- .u-breakWords.u-breakWords {
- word-break: break-word;
- @supports (overflow-wrap: break-word) {
- overflow-wrap: break-word;
- word-break: unset;
- }
- }
- .zIndex-1 {
- z-index: 100;
- }
- .zIndex-2 {
- z-index: 200;
- }
- .zIndex-3 {
- z-index: 300;
- }
- .zIndex-4 {
- z-index: 400;
- }
- .zIndex-5 {
- z-index: 500;
- }
- .zIndex-6 {
- z-index: 600;
- }
- .zIndex-7 {
- z-index: 700;
- }
- .zIndex-8 {
- z-index: 800;
- }
- .zIndex-9 {
- z-index: 900;
- }
- .zIndex-10 {
- z-index: 1000;
- }
- .zIndex-11 {
- z-index: 1100;
- }
- .zIndex-12 {
- z-index: 1200;
- }
- .clickCatcher {
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- position: absolute;
- cursor: default;
- }
- .debug .clickCatcher {
- background: hsla(0, 100%, 50%, 0.13);
- }
- .debug .clickCatcher + .clickCatcher {
- background: hsla(50, 100%, 50%, 0.13);
- }
- .clearfix::after {
- visibility: hidden;
- display: block;
- font-size: 0;
- content: ' ';
- clear: both;
- height: 0;
- }
- .clearfix {
- display: inline-block;
- }
- /* start commented backslash hack \ */
- * html .clearfix {
- height: 1%;
- }
- .clearfix {
- display: block;
- }
- /* close commented backslash hack */
- /* Avoid too broad selectors, since they can affect unintended elements in third-party extensions (#5073). */
- [contenteditable='true'],
- .richtext-content[contenteditable] {
- display: block;
- outline-style: none;
- border-radius: 3px;
- /* needed to make empty tags editable, otherwise no focus can be set */
- min-height: 10px;
- min-width: 20px;
- &:hover,
- &:focus {
- background: var(--background-primary);
- }
- &:focus {
- text-overflow: clip !important;
- }
- &.invalid {
- background: #f92;
- }
- & > .placeholder {
- color: var(--text-muted);
- }
- p {
- margin: 0;
- }
- }
- /* fix for placeholder */
- .Medium-placeholder {
- position: relative;
- }
- .close,
- .close:hover {
- float: none;
- opacity: 1;
- }
- #app > nav {
- position: relative;
- z-index: 1;
- }
- code {
- background: var(--background-modifier-accent);
- border-radius: 3px;
- box-decoration-break: clone;
- }
- code,
- .hljs {
- padding: 2px 4px;
- font-size: 0.88em;
- }
- .hljs {
- background: none;
- @include dark {
- filter: invert(1);
- }
- }
- pre code.hljs {
- font-size: 1em;
- }
- pre {
- display: block;
- padding: 9.5px;
- margin: 0 0 20px;
- font-size: 13px;
- line-height: 1.42857143;
- word-break: break-all;
- word-wrap: break-word;
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 3px;
- }
- .modal-content pre {
- background: var(--background-modifier-accent);
- border-color: var(--background-modifier-border);
- }
- pre code {
- padding: 0;
- font-size: inherit;
- color: inherit;
- white-space: pre-wrap;
- background: none;
- border-radius: 0;
- border: none;
- overflow-x: auto;
- &.hljs {
- padding: 0;
- background: none;
- }
- }
- .textarea::placeholder,
- .form-control::placeholder,
- .token-input::placeholder,
- .u-placeholder {
- color: var(--ghost-color);
- }
- .btn {
- display: inline-block;
- font-size: 14px;
- padding: 10px 24px 9px;
- color: var(--text-normal);
- background: var(--button-background);
- border: 1px solid var(--border);
- outline: none !important;
- border-radius: 4px;
- text-align: center;
- white-space: nowrap;
- vertical-align: middle;
- text-decoration: none;
- @extend %clickable;
- @include phone {
- padding-left: 12px;
- padding-right: 12px;
- }
- .icon {
- vertical-align: middle;
- margin-top: -2px;
- @include bidi-style(margin-right, 5px, margin-right, -2px);
- @include bidi-style(margin-left, -2px, margin-right, 5px);
- flex-shrink: 0;
- &.icon-arrow-up {
- margin-top: -3px;
- }
- }
- span {
- min-width: 0;
- overflow: hidden;
- text-overflow: ellipsis;
- display: block;
- }
- &--only-icon .icon,
- &--icon-only .icon {
- margin-left: 0 !important;
- margin-right: 0 !important;
- }
- &--icon--last .icon {
- @include bidi-style(
- margin-left,
- 5px,
- margin-right,
- 0
- ); // so far only used in ticket_zoom secondaryAction dropup
- }
- &:focus {
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- }
- &--small {
- padding-top: 5px;
- padding-bottom: 4px;
- &.btn--quad {
- padding: 4px 5px;
- }
- }
- &--slim {
- padding-left: 12px;
- padding-right: 12px;
- }
- &--fullWidth {
- width: 100%;
- text-align: center;
- justify-content: center;
- }
- &.is-disabled,
- &[disabled],
- &:disabled {
- pointer-events: none;
- cursor: not-allowed;
- opacity: 0.33;
- }
- &:active {
- box-shadow: none;
- background: var(--button-background-active);
- }
- &--capitalized {
- text-transform: capitalize;
- }
- &--action {
- text-transform: uppercase;
- color: var(--button-action-color);
- font-size: 12px;
- letter-spacing: 0.05em;
- height: 31px;
- padding: 0 11px !important;
- display: inline-flex;
- align-items: center;
- min-width: 0;
- .icon {
- @include ltr(margin, -2px 5px 0 -2px);
- @include rtl(margin, -2px -2px 0 5px);
- }
- .icon:only-child {
- margin: 0 !important;
- }
- &.btn--slim {
- padding-left: 7px !important;
- padding-right: 7px !important;
- .btn-label {
- @include bidi-style(margin-left, 0, margin-right, 0);
- }
- &.btn--small {
- padding-left: 5px !important;
- padding-right: 5px !important;
- }
- }
- &.btn--small {
- height: 26px;
- font-size: 11px;
- padding-left: 8px !important;
- padding-right: 8px !important;
- }
- }
- &-active-icon {
- display: none;
- }
- &--active {
- background: var(--button-active);
- color: var(--text-inverted);
- &:active {
- background: var(--button-active-active);
- }
- .btn-inactive-icon {
- display: none;
- }
- .btn-active-icon {
- display: inline;
- }
- }
- // used in .recipientList-controls
- &--onDark {
- background: var(--background-modifier-lighter);
- border-color: var(--background-modifier-accent-dark);
- color: var(--text-inverted);
- .icon {
- opacity: 1;
- }
- }
- &--primary {
- color: var(--button-primary-text);
- background: var(--button-primary-background);
- &:active {
- background: var(--button-primary-background-active);
- }
- .icon {
- opacity: 1;
- fill: currentColor;
- }
- }
- &--secondary {
- color: var(--button-primary-background);
- }
- &--positive,
- &--create,
- &--success {
- color: var(--text-inverted);
- background: hsl(145, 51%, 45%);
- &:active {
- background: hsl(145, 51%, 35%);
- }
- &.btn--secondary {
- background: var(--background-secondary);
- color: hsl(145, 51%, 45%);
- &:active {
- background: var(--button-background-active);
- }
- }
- &.btn--text {
- color: var(--supergood-color);
- }
- }
- &--danger {
- color: var(--text-inverted);
- background: var(--danger-color);
- &:active {
- background: linear-gradient(hsla(0, 0%, 0%, 0.1), hsla(0, 0%, 0%, 0.1)),
- linear-gradient(var(--danger-color), var(--danger-color));
- }
- &.btn--secondary {
- background: var(--background-secondary);
- color: var(--danger-color);
- &:active {
- background: var(--button-background-active);
- }
- }
- }
- &--text {
- display: inline-flex;
- align-items: center;
- font-size: inherit;
- margin: -10px;
- padding: 10px;
- color: var(--text-button-primary);
- border: none;
- background: none;
- vertical-align: baseline;
- text-align: start;
- .table & {
- margin: 0;
- min-height: 38px;
- }
- &.no-padding {
- padding: 0;
- margin: 0;
- min-height: auto;
- }
- .icon {
- opacity: 1;
- @include bidi-style(margin-left, -2px, margin-right, 6px);
- @include bidi-style(margin-right, 6px, margin-right, -2px);
- width: 16px;
- max-height: 16px;
- object-fit: contain;
- }
- &.btn--icon--last .icon {
- @include bidi-style(margin-left, 6px, margin-right, -2px);
- @include bidi-style(margin-right, -2px, margin-right, 6px);
- }
- &:active {
- color: var(--text-button-primary-active);
- background: none;
- }
- &.btn--secondary {
- color: var(--text-button-secondary);
- text-decoration: underline;
- &:active {
- opacity: 0.75;
- }
- }
- &.btn--positive {
- color: hsl(145, 51%, 45%);
- &:active {
- color: hsl(145, 51%, 30%);
- background: none;
- }
- }
- &.btn--danger {
- color: var(--danger-color);
- &:active {
- color: hsl(0, 65%, 40%);
- background: none;
- }
- }
- &.btn--subtle {
- text-decoration: underline;
- color: var(--text-button-secondary);
- &:active {
- opacity: 0.75;
- }
- }
- &.space-left {
- @include bidi-style(margin-left, 0, margin-right, -10px);
- }
- &.space-right {
- @include bidi-style(margin-right, 0, margin-left, -10px);
- }
- }
- &--large {
- &.btn--text {
- margin: 0;
- }
- }
- &--quad {
- padding: 10px 12px 9px;
- .icon {
- margin: -1px;
- }
- }
- &--split--first {
- @include bidi-style(border-radius, 3px 0 0 3px, border-radius, 0 3px 3px 0);
- }
- &--split,
- &--split--last {
- border-radius: 0;
- @include bidi-style(border-left-width, 0, border-right-width, 1px);
- @include ltr(margin-left, 0 !important);
- @include rtl(margin-right, 0 !important);
- .icon {
- margin-left: 2px !important;
- margin-right: 2px !important;
- }
- }
- &--split--last {
- @include bidi-style(border-radius, 0 3px 3px 0, border-radius, 3px 0 0 3px);
- }
- &--dropdown {
- position: relative;
- select {
- opacity: 0;
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
- position: absolute;
- @extend %clickable;
- }
- }
- }
- .btn + .btn,
- .btn + .buttonDropdown,
- .buttonDropdown + .buttonDropdown {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- .btn + .btn.align-right {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- .btn.align-right ~ .btn {
- @include bidi-style(margin-left, 15px, margin-right, 0);
- }
- .vertical > .btn:not(.hidden) + .btn {
- @include bidi-style(margin-left, 0, margin-right, 0);
- margin-top: 10px;
- &--text {
- @include bidi-style(margin-left, -10px, margin-right, -10px);
- margin-top: 0;
- }
- }
- .btn--download .icon-download {
- margin-right: 6px;
- @include rtl(margin-right, -10px);
- margin-top: 4px;
- margin-left: -10px;
- @include rtl(margin-left, 6px);
- vertical-align: top;
- fill: var(--text-inverted);
- }
- .btn-label {
- @include bidi-style(margin-left, 7px, margin-right, 0);
- }
- .btn-show-all {
- &[aria-expanded='false'] [data-show='collapsed'],
- &[aria-expanded='true'] [data-show='open'] {
- display: none;
- }
- .icon {
- margin-left: 0;
- margin-right: 0;
- }
- }
- .visibility-change {
- /*
- Interactive Visibility Change Classes:
- <div class="visibility-change">
- <svg class="icon-marker" data-visible="active"><use xlink:href="#icon-marker" /></svg>
- </div>
- Important: HTML Order active > hover > normal
- */
- [data-visible='active'],
- [data-visible='hover'] {
- display: none;
- }
- &.is-active [data-visible='active'] {
- display: block;
- & ~ [data-visible='normal'] {
- display: none;
- }
- }
- &:hover [data-visible='hover'] {
- display: block;
- & ~ [data-visible='normal'] {
- display: none;
- }
- }
- }
- .btn-group {
- display: inline-flex;
- flex-wrap: wrap;
- &--full {
- display: flex;
- }
- & + .btn-group {
- margin-top: 10px;
- padding-top: 10px;
- border-top: 1px solid var(--border);
- }
- .btn {
- &:not(:first-child) {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- }
- &:not(:last-child) {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- border-right-width: 0;
- }
- + .btn {
- @include bidi-style(margin-left, 0, margin-right, 10px);
- }
- }
- .btn--text {
- padding: 6px 10px 5px; /* reporting main.eco */
- display: inline-block;
- border-radius: 3px;
- &.is-selected {
- background: var(--button-primary-background);
- color: var(--text-inverted);
- }
- }
- }
- .buttonDropdown {
- display: flex;
- align-items: center;
- position: relative;
- user-select: none;
- .dropdown-menu {
- margin-bottom: 0;
- }
- &.is-open .dropdown-menu {
- display: block;
- }
- .btn--text {
- padding-left: 13px;
- padding-right: 13px;
- }
- .dropdown-menu-accessories {
- cursor: pointer;
- &:focus {
- outline: none;
- .dropdown-menu {
- display: block;
- }
- .btn--split--last {
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- pointer-events: initial;
- }
- }
- .btn--split--last {
- pointer-events: none;
- &:focus {
- box-shadow: none;
- pointer-events: none;
- }
- &:active {
- background-color: #429ed7;
- }
- }
- }
- }
- .dropdown-menu-right {
- @include rtl(right, auto);
- @include rtl(left, 0);
- }
- .dropdown-menu-left {
- @include rtl(left, auto);
- @include rtl(right, 0);
- }
- .status-fields {
- display: flex;
- max-width: 100%;
- @include phone {
- display: block;
- }
- .dropdown li {
- display: flex;
- align-items: center;
- padding: 0 10px;
- }
- .dropdown-menu .status-badge {
- margin-left: 10px;
- }
- .dropdown-menu .badge {
- margin-top: -2px;
- margin-right: 7px;
- background: hsla(0, 0%, 0%, 0.5);
- }
- }
- .status-field {
- border: 1px solid var(--border);
- background: var(--button-background);
- display: flex;
- height: 34px;
- flex-shrink: 1;
- min-width: 20px;
- padding: 5px 0;
- align-items: center;
- white-space: nowrap;
- text-overflow: ellipsis;
- overflow: hidden;
- @include phone {
- border-bottom-width: 0;
- }
- &.is-active {
- background: var(--button-primary-background);
- color: var(--text-inverted);
- border-color: var(--button-primary-background-active);
- box-shadow: 1px 0 var(--button-primary-background-active);
- position: relative;
- @extend %clickable;
- .icon {
- fill: currentColor;
- opacity: 1;
- }
- }
- &:not(:last-child, :only-child) {
- @include bidi-style(border-right-width, 0, border-left-width, 1px);
- @include phone {
- border-right-width: 1px !important;
- }
- }
- &:first-child {
- border-radius: 5px 0 0 5px;
- @include rtl(border-radius, 0 5px 5px 0);
- @include phone {
- border-radius: 5px 5px 0 0 !important;
- .dropdown & {
- flex: 1;
- border-top-right-radius: 0 !important;
- border-right-width: 0 !important;
- }
- }
- .dropdown.open & {
- border-radius: 5px 0 0;
- @include rtl(border-radius, 0 5px 0 0);
- @include phone {
- border-radius: 5px 0 0 !important;
- }
- }
- }
- &:last-child {
- border-radius: 0 5px 5px 0;
- @include rtl(border-radius, 5px 0 0 5px);
- @include phone {
- border-radius: 0 0 5px 5px !important;
- border-bottom-width: 1px;
- }
- }
- &:only-child {
- border-radius: 5px;
- @include phone {
- border-radius: 5px !important;
- }
- }
- .badge {
- @include bidi-style(margin, 0 7px 0 10px, margin, 0 10px 0 7px);
- background: hsla(210, 50%, 10%, 0.24);
- }
- .status-badge {
- width: 32px;
- display: inline-flex;
- align-items: center;
- justify-content: center;
- align-self: stretch;
- }
- &--arrow {
- @extend %clickable;
- border-left: none;
- width: 34px;
- justify-content: center;
- @include phone {
- border-top-right-radius: 5px !important;
- }
- }
- &--spacer {
- padding-left: 16px;
- padding-right: 2px;
- }
- }
- .status-badge {
- display: inline-block;
- }
- .info-badge {
- fill: currentColor;
- padding: 3px 6px 1px;
- line-height: 12px;
- opacity: 0.5;
- position: relative;
- /*
- border in its own layer to make it more
- translucend but still depend on the currentColor
- */
- &::after {
- content: '';
- position: absolute;
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
- border: 1px solid currentColor;
- opacity: 0.5;
- border-radius: 100%;
- }
- }
- @keyframes pulsate {
- to {
- filter: brightness(1.2);
- }
- }
- .badge {
- display: inline-block;
- min-width: 18px;
- padding: 3px 5px;
- font-size: 12px;
- font-weight: 500;
- line-height: 1;
- color: var(--text-inverted);
- text-align: center;
- white-space: nowrap;
- vertical-align: top;
- border-radius: 9px;
- background: var(--border-alt);
- @include bidi-style(margin-right, 3px, margin-left, 0);
- flex-shrink: 0;
- &:empty {
- display: none;
- }
- &.badge--big {
- min-width: 22px;
- font-size: 14px;
- border-radius: 11px;
- padding: 5px 7px 3px;
- }
- &.badge--text {
- min-width: 0;
- padding: 0;
- margin-right: 0;
- @include bidi-style(margin-right, 0, margin-left, 0);
- font-size: inherit;
- font-weight: inherit;
- text-align: inherit;
- line-height: inherit;
- color: var(--text-muted);
- background: none;
- border-radius: 0;
- vertical-align: baseline;
- }
- &.badge--primary {
- background: var(--highlight);
- }
- }
- .key-value {
- td:first-child {
- @include bidi-style(padding-right, 10px, padding-left, 0);
- color: var(--text-muted);
- }
- }
- table {
- table-layout: fixed;
- }
- .scroll-table-container {
- overflow: hidden;
- overflow-y: scroll;
- max-height: 244px;
- table > thead > tr > th {
- @extend .zIndex-2;
- top: 0;
- position: sticky;
- }
- }
- .table {
- display: table;
- small {
- color: inherit;
- }
- &-icon {
- max-width: 20px;
- max-height: 20px;
- object-fit: contain;
- vertical-align: middle;
- fill: hsla(0, 0%, 0%, 0.3);
- }
- &-buttons {
- padding-top: 0 !important;
- padding-bottom: 0 !important;
- height: 38px;
- display: flex;
- align-items: center;
- justify-content: flex-end;
- text-align: right;
- }
- }
- .table--light {
- color: var(--text-muted);
- }
- .table-fluid {
- table-layout: auto;
- }
- .table .table-row {
- display: table-row;
- }
- .table.table--placeholder {
- th {
- text-align: center;
- }
- td {
- height: 40px;
- }
- > thead > tr > th {
- background: var(--background-modifier-accent);
- }
- }
- .table th:not(.noTruncate) .table-column-title,
- .table td:not(.noTruncate) {
- @extend .u-textTruncate;
- }
- .table > thead > tr > th {
- padding: 12px 9px 10px;
- border-bottom: none;
- border-top: 1px solid #ececec;
- background: var(--background-primary-alt);
- color: var(--text-normal);
- font-weight: normal;
- font-size: 12px;
- text-transform: uppercase;
- letter-spacing: 0.05em;
- position: relative;
- user-select: none;
- }
- .table-column-head {
- display: flex;
- @extend %clickable;
- &-unclickable {
- cursor: default;
- }
- }
- .table-column-sortIcon {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- th.align-right {
- .table-column-title {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- .table-column-sortIcon {
- @include bidi-style(margin-left, 0, margin-right, 0);
- }
- }
- td.align-right {
- @include bidi-style(text-align, right, text-align, left);
- }
- .table-striped > tbody > tr:nth-child(2n + 1) {
- background-color: var(--background-secondary);
- }
- .table > tbody > tr > td {
- padding: 10px 10px 8px;
- border-color: var(--background-modifier-accent);
- &.no-side-padding {
- padding-left: 0;
- padding-right: 0;
- text-align: center;
- }
- }
- .table > tbody > tr.u-center > td {
- vertical-align: middle;
- }
- .table-hover > tbody > tr:hover,
- .table-hover > tbody > tr.is-hover {
- background: var(--background-secondary);
- }
- .table-hover-in-modal > tbody > tr:hover > td {
- background-color: var(--background-primary);
- }
- .table-hover > tbody > tr:hover > th {
- background: rgba(0, 8, 14, 0.015);
- }
- .table-col-resize {
- position: absolute;
- @include bidi-style(right, 0, left, auto);
- top: 0;
- height: 100%;
- cursor: col-resize;
- padding: 10px;
- @include bidi-style(margin-right, -10px, margin-left, 0);
- z-index: 1;
- &::after {
- content: '';
- display: block;
- width: 1px;
- height: 100%;
- background: var(--border);
- }
- }
- .table > thead:first-child > tr:first-child > th.no-padding,
- .table > thead > tr > th.no-padding,
- .table > tbody > tr > td.no-padding {
- padding: 0;
- }
- .table tr.is-inactive,
- .table tr td span.is-inactive {
- color: var(--text-muted);
- text-decoration: line-through;
- a {
- color: inherit;
- }
- }
- .table tr.is-grayed-out {
- color: var(--text-muted);
- .icon:not(.u-highlight),
- .btn span {
- opacity: 0.33;
- }
- .avatar {
- opacity: 0.5;
- }
- .avatar--unique {
- background: var(--background-secondary-hover);
- text-shadow: none;
- opacity: initial;
- }
- }
- td .icon {
- vertical-align: middle;
- margin-top: -3px;
- }
- td .icon-draggable,
- td .icon-trash {
- vertical-align: middle;
- }
- td .prefix-icon > .icon {
- vertical-align: top;
- }
- td .icon-cog {
- width: 16px;
- }
- .table-checkbox,
- .table-radio {
- padding: 0 !important;
- .icon {
- margin-top: 0;
- }
- }
- .table .table-sort-arrow {
- opacity: 1;
- width: 8px;
- height: 8px;
- @include bidi-style(margin-left, 3px, margin-right, 0);
- margin-top: -2px;
- vertical-align: middle;
- }
- .item {
- &--high-priority {
- a {
- color: $high-priority-color;
- }
- }
- &--low-priority {
- a {
- color: $low-priority-color;
- }
- }
- }
- .checkbox-list {
- list-style: none;
- margin-bottom: 15px;
- padding: 3px 12px;
- font-size: 14px;
- line-height: 25px;
- color: var(--text-normal);
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 3px;
- }
- .checkbox-replacement,
- .radio-replacement {
- padding: 0;
- margin: 0;
- display: flex;
- align-items: center;
- justify-content: center;
- position: relative;
- @extend .u-clickable;
- > .icon {
- vertical-align: middle;
- margin-top: -2px;
- fill: var(--button-background);
- @include dark {
- fill: transparent;
- }
- }
- .icon-checked {
- color: var(--interactive-primary);
- }
- .icon-unchecked {
- color: var(--text-muted);
- }
- .icon-indeterminate {
- display: none;
- color: var(--text-muted);
- }
- &.is-disabled {
- cursor: not-allowed;
- }
- &.checkbox-replacement--fullscreen,
- &.radio-replacement--fullscreen {
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- }
- &.checkbox-replacement--inline,
- &.radio-replacement--inline {
- display: inline-flex;
- @include bidi-style(margin-right, 3px, margin-left, 0);
- }
- input[type='checkbox'],
- input[type='radio'] {
- position: absolute;
- opacity: 0;
- cursor: pointer;
- &:disabled {
- cursor: not-allowed;
- ~ .icon {
- opacity: 0.33;
- fill: none;
- }
- }
- &:not(:checked) ~ .icon-checked,
- &:checked ~ .icon-unchecked {
- display: none;
- }
- &:focus:not(.is-active) ~ .icon-checked,
- &:focus:not(.is-active) ~ .icon-unchecked {
- box-shadow:
- 0 0 0 2px var(--border-highlight),
- 0 0 0 3px var(--shadow-highlight);
- }
- }
- + .label-text {
- @include bidi-style(margin-left, 0, margin-right, 3px);
- }
- }
- .checkbox-replacement {
- &:indeterminate {
- ~ .icon-checked,
- ~ .icon-unchecked {
- display: none;
- }
- ~ .icon-indeterminate {
- display: block;
- }
- }
- }
- .radio-replacement {
- input:focus ~ .icon-checked,
- input:focus ~ .icon-unchecked {
- border-radius: 100%;
- }
- > .icon {
- margin-top: -3px;
- }
- }
- .table .checkbox-replacement,
- .table .radio-replacement {
- height: 40px;
- width: 40px;
- &.checkbox-replacement--fullscreen {
- width: 100%;
- height: 100%;
- }
- }
- .table-overview tbody .icon-checkbox,
- .table-overview tbody .icon-radio,
- .table-overview tbody .icon-checkbox-checked,
- .table-overview tbody .icon-radio-checked {
- fill: transparent;
- }
- .table .table-cell {
- vertical-align: top;
- display: table-cell;
- border-bottom: 1px solid var(--background-primary-alt);
- }
- .hero-two {
- width: 100%;
- }
- .hero-two .hero-left {
- width: 50%;
- float: left;
- }
- .hero-two .hero-right {
- width: 50%;
- float: right;
- }
- .max-size-scroll {
- max-height: 240px;
- overflow-y: scroll;
- }
- /*
- #content > *:not(.active) {
- display: none !important;
- }
- */
- h1,
- h2,
- h3,
- h4,
- h5,
- h6 {
- font-weight: normal;
- color: var(--header-primary);
- }
- h1 {
- font-size: 24px;
- line-height: 30px;
- }
- h2,
- h2.popover-title {
- font-size: 20px;
- line-height: 25px;
- }
- h3 {
- font-size: 16px;
- margin: 20px 0 8px;
- font-weight: normal;
- .subtitle {
- display: inline;
- font-size: 12px;
- text-transform: none;
- color: var(--text-muted);
- letter-spacing: initial;
- }
- }
- h4 {
- font-size: 13px;
- text-transform: uppercase;
- }
- h5 {
- font-size: 13px;
- font-weight: bold;
- }
- label,
- .checkbox.form-group label,
- .label {
- text-transform: uppercase;
- color: var(--text-muted);
- display: block;
- font-size: 13px;
- font-weight: normal;
- letter-spacing: 0.05em;
- margin-bottom: 4px;
- text-align: start;
- padding: 0;
- &.input-group-addon {
- color: var(--text-muted);
- }
- /* user-select: none; disabled because of chrome51 https://github.com/martini/zammad/issues/183 */
- h2 & {
- color: inherit !important;
- font-size: inherit;
- font-weight: inherit;
- letter-spacing: 0;
- margin-bottom: 0;
- padding: 0 !important;
- text-transform: inherit;
- }
- }
- /* circumventing the label:not(.inline-label) selector because it's too strong */
- .inline-label,
- .label-success,
- .label-warning,
- .label-danger {
- font-size: inherit;
- font-weight: inherit;
- text-align: inherit;
- color: inherit;
- letter-spacing: 0;
- margin: 0;
- text-transform: none;
- display: inline;
- }
- table {
- .inline-label,
- .label-success,
- .label-warning,
- .label-danger {
- white-space: nowrap; /* for labels in tables that might get crushed view: calendar_subscriptions */
- }
- }
- .label-text {
- @include bidi-style(margin-left, 3px, margin-right, 0);
- @extend %clickable;
- }
- .label-success,
- .label-warning,
- .label-danger {
- background: none;
- }
- .label-success {
- color: var(--supergood-color);
- }
- .label-highlight {
- color: var(--highlight);
- }
- .label-warning {
- color: var(--ok-color);
- }
- .label-danger {
- color: var(--superbad-color);
- }
- .label-subtle {
- color: var(--ghost-color);
- }
- .state-archived,
- .state-draft {
- color: hsl(0, 0%, 68%);
- }
- .state-published {
- color: var(--supergood-color);
- }
- .state-internal {
- color: var(--highlight);
- }
- fieldset {
- margin: 0 -4px;
- @extend .clearfix;
- @include phone {
- width: calc(100% + 8px);
- }
- h2,
- .help-text {
- margin-left: 4px;
- margin-right: 4px;
- }
- }
- .form-field-group {
- padding: 20px;
- background: var(--background-secondary);
- border-radius: 4px;
- margin-bottom: 16px;
- border: 1px solid var(--border);
- .modal-body & {
- background: var(--background-primary);
- }
- > .form-group:last-child {
- margin-bottom: 0;
- }
- }
- fieldset > .form-group {
- padding: 0 4px;
- }
- .form-group {
- margin-bottom: 16px;
- &.form-group--inactive {
- opacity: 0.5;
- }
- &.is-readonly .controls:not(.ignore-readonly) {
- pointer-events: none;
- cursor: not-allowed !important;
- input:read-only.form-control:not(.js-input, .js-objectSelect) {
- pointer-events: auto;
- cursor: auto;
- }
- }
- &.form-group--nested {
- @include bidi-style(padding-left, 30px, padding-right, 30px);
- }
- &.form-group--wide {
- @include bidi-style(margin-left, -30px, margin-right, -30px);
- }
- }
- .date.form-group .controls {
- position: relative;
- }
- .form-group + .form-group {
- margin-top: 0;
- }
- .merge-group {
- display: flex;
- align-items: stretch;
- &.merge-group--header {
- h2 {
- margin-bottom: 0;
- }
- label {
- display: inline;
- }
- .merge-source,
- .merge-target {
- border-bottom: 1px solid var(--border);
- }
- }
- .merge-target,
- .merge-source {
- flex: 1;
- width: 33%;
- display: flex;
- flex-direction: column;
- justify-content: flex-end;
- }
- .merge-source,
- .merge-target {
- padding-bottom: 3px;
- border-left: 1px solid var(--border);
- border-right: 1px solid var(--border);
- padding: 7px 13px;
- }
- &:first-of-type {
- margin-top: 6px;
- .merge-source,
- .merge-target {
- border-top: 1px solid var(--border);
- border-radius: 3px 3px 0 0;
- }
- }
- &:last-of-type {
- margin-bottom: 6px;
- .merge-source,
- .merge-target {
- border-bottom: 1px solid var(--border);
- border-radius: 0 0 3px 3px;
- }
- }
- .merge-value {
- margin-bottom: 3px;
- }
- .form-group {
- padding: 0;
- }
- .form-control {
- margin: 0 !important;
- }
- &.merge-group--multi {
- .merge-value + .merge-value {
- margin-top: 12px;
- }
- }
- }
- .merge-controls {
- flex: 1;
- align-self: flex-end;
- }
- .merge-control {
- margin-bottom: 5px;
- height: 31px;
- text-align: center;
- display: flex;
- flex: 1;
- justify-content: space-between;
- align-items: center;
- align-self: flex-end;
- }
- .merge-control-input {
- flex: 1;
- }
- .merge-arrow {
- margin: 0 12px;
- display: flex;
- align-items: center;
- justify-content: center;
- .line-arrow {
- fill: var(--border);
- }
- }
- .formGroup-label {
- padding: 0 2px;
- margin-bottom: 5px;
- position: relative;
- display: flex;
- align-items: center;
- h2 & {
- padding: 0;
- margin: 0;
- }
- label {
- margin: 0;
- }
- a[data-toggle='collapse'] > label {
- cursor: pointer;
- color: var(--text-link);
- }
- a[data-toggle='collapse'] {
- &:focus,
- &:active {
- text-decoration: underline;
- }
- &.collapsed {
- & svg {
- &.icon-arrow-right {
- display: inline;
- }
- &.icon-arrow-down {
- display: none;
- }
- }
- }
- &:not(.collapsed) {
- & svg {
- &.icon-arrow-right {
- display: none;
- }
- &.icon-arrow-down {
- display: inline;
- }
- }
- }
- }
- .bookmark.icon {
- margin-bottom: -1px;
- }
- .formGroup-metaControl {
- @extend .u-clickable;
- padding: 6px 4px;
- margin: -6px 0 -6px auto;
- font-size: 20px;
- line-height: 1;
- color: var(--interactive-muted);
- }
- }
- .formGroup-bookmark {
- @extend .u-clickable;
- display: flex;
- align-items: center;
- flex-direction: row-reverse;
- width: 30px;
- height: 30px;
- position: absolute;
- right: 0;
- top: -10px;
- }
- .form-group .controls .richtext {
- position: relative;
- height: auto;
- }
- .form-group .help-message {
- cursor: help;
- color: var(--interactive-muted);
- top: -2px;
- position: relative;
- @include bidi-style(margin-left, auto, margin-right, 0);
- .icon-help {
- display: block;
- }
- }
- .form-group:not(.formGroup--halfSize) {
- clear: left;
- }
- .form-group.formGroup--halfSize {
- width: 50%;
- float: left;
- @include phone {
- width: auto;
- float: none;
- }
- .form-control {
- min-width: initial;
- }
- }
- .formGroup--standalone .form-control {
- margin-bottom: 0;
- }
- .controls--select {
- position: relative;
- }
- .controls--datetime {
- position: relative;
- display: flex;
- }
- .controls--date {
- position: relative;
- }
- .controls--datetime {
- position: relative;
- display: flex;
- }
- .controls--date {
- position: relative;
- }
- .controls--grow {
- flex-grow: 1;
- }
- .controls-label {
- margin: 11px 10px 0;
- flex-shrink: 0;
- .form-control--small + & {
- margin-top: 7px;
- }
- }
- /* do not show safari auto fill icon - see issue #962 */
- input::-webkit-contacts-auto-fill-button {
- visibility: hidden;
- display: none !important;
- pointer-events: none;
- position: absolute;
- right: 0;
- }
- input[type='radio'],
- input[type='checkbox'] {
- margin: 0;
- }
- input[type='text'],
- input[type='password'],
- input[type='email'],
- input[type='date'],
- input[type='url'],
- textarea,
- .form-control,
- .form-group .checkbox,
- .form-group .radio {
- display: block;
- padding: 7px 12px;
- width: 100%;
- height: 41px;
- font-size: 14px;
- font-weight: normal;
- line-height: 25px;
- color: var(--text-normal);
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 3px;
- transition: none;
- box-shadow: none;
- outline: none;
- appearance: none;
- @include phone {
- font-size: 16px;
- }
- .modal-body &,
- .box &,
- .sidebar &,
- .hero-unit &,
- .form-field-group &,
- .popover & {
- background: var(--background-primary);
- }
- .modal-body .form-field-group &,
- .formset-inset & {
- background: var(--background-secondary);
- }
- &.form-control--small {
- padding: 5px 8px 4px;
- height: 30px;
- line-height: 20px;
- &[multiple] {
- height: auto;
- }
- &.form-control--multiline {
- min-height: 30px;
- }
- }
- &.form-control--inline {
- display: inline-block;
- width: auto;
- }
- &.form-control--multiline {
- height: auto;
- min-height: 41px;
- }
- &:focus,
- &:focus-within,
- &.focus {
- border-color: var(--border-highlight);
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- }
- &.is-disabled, // .is-disabled should not be used - legacy support
- &[disabled],
- &[readonly] {
- background: var(--background-secondary);
- opacity: 0.38;
- &:focus,
- &.focus {
- border-color: var(--border-highlight);
- }
- }
- &.is-disabled, // .is-disabled should not be used
- &[disabled] {
- cursor: not-allowed;
- }
- }
- input[type='url'] {
- min-width: 400px;
- }
- .sidebar-content input[type='url'] {
- min-width: inherit;
- }
- .user-select.form-control {
- padding-right: 35px;
- min-width: 300px;
- }
- input[type='time'] {
- width: auto;
- padding-left: 6px;
- padding-right: 6px;
- }
- input.timeframe,
- input.time {
- box-sizing: content-box;
- padding: 0 6px;
- height: 39px;
- line-height: 42px;
- flex-shrink: 0;
- &.form-control--small {
- line-height: 20px;
- padding-top: 0;
- padding-bottom: 0;
- }
- }
- input.timeframe {
- width: 5.5ch;
- }
- input.time {
- width: 4.5ch;
- }
- input.time.time--12 {
- width: 7.5ch;
- }
- .tokenfield.focus {
- border-color: var(--border-highlight);
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- }
- .richtext.form-control {
- padding: 0;
- }
- .richtext.form-control [contenteditable] {
- height: auto;
- min-height: 82px;
- background: none;
- padding: 7px 12px 35px;
- }
- .richtext.form-control [contenteditable='false'] {
- cursor: not-allowed;
- opacity: 0.38;
- border-color: var(--border);
- padding: unset;
- &:focus,
- &.focus {
- border-color: var(--border-highlight);
- }
- }
- .richtext.is-readonly [contenteditable='false'] {
- cursor: default;
- opacity: 1;
- padding: 7px 12px;
- }
- .richtext.form-control .attachments.attachments--list:not(:empty) {
- border-top: 1px solid var(--background-modifier-border);
- white-space: normal;
- margin: 0 -12px -28px;
- padding: 25px 20px 21px 72px;
- position: relative;
- line-height: 1;
- }
- .richtext-controls {
- display: flex;
- margin: 7px 7px 0;
- padding: 3px 5px 10px;
- border-bottom: 1px solid var(--background-modifier-border);
- @include phone {
- flex-wrap: nowrap;
- }
- }
- textarea.form-control {
- height: 118px;
- resize: vertical;
- &[rows] {
- height: auto;
- }
- }
- select.form-control:not([multiple]) {
- @include bidi-style(padding-right, 34px, padding-left, 12px);
- word-wrap: normal;
- }
- .form-control.is-hidden {
- display: none;
- }
- .form-control.form-control--borderless {
- border: none;
- padding: 0;
- line-height: inherit;
- height: auto;
- &:focus {
- box-shadow: none;
- }
- }
- select[multiple],
- select[multiple]:focus {
- option:checked {
- color: var(--interactive-primary);
- background: var(--ghost-color);
- }
- }
- .select.form-group,
- .user_autocompletion.form-group {
- .form-control:not([multiple]) {
- @include ltr(padding-right, 21px);
- }
- }
- .form-control + .icon-arrow-down,
- .dropdown-arrow {
- position: absolute;
- @include bidi-style(right, 12px, left, auto);
- top: 50%;
- margin-top: -3px;
- width: 13px;
- height: 7px;
- @extend .u-unclickable;
- }
- .dropdown-clear {
- position: absolute;
- padding: 1px;
- @include bidi-style(right, 12px, left, auto);
- &--with-arrow-icon {
- @include bidi-style(right, 35px, left, auto);
- }
- top: 50%;
- margin-top: -7px;
- border: 1px solid transparent;
- .icon-diagonal-cross {
- display: block;
- width: 10px;
- height: 10px;
- fill: var(--interactive-muted);
- }
- &:focus {
- outline: none;
- border-radius: 3px;
- border-color: var(--border-highlight);
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- }
- }
- select::-ms-expand {
- display: none;
- }
- .has-error .form-control,
- .has-error .form-control:focus,
- .has-error .form-control.focus {
- box-shadow: none;
- border-color: var(--danger-color) !important;
- }
- input.has-error {
- box-shadow: none;
- border-color: var(--danger-color) !important;
- }
- .help-inline:not(:empty) {
- color: var(--danger-color);
- padding: 2px;
- font-size: 13px;
- }
- .zammad-form-modal-body {
- background: var(--background-primary) !important;
- }
- /* use on input[type=radio] */
- .primary-email-switch {
- display: none;
- & + label {
- font-size: 11px;
- color: var(--interactive-muted);
- margin: 0;
- @extend %clickable;
- }
- &:checked + label {
- color: var(--highlight);
- }
- }
- .primary-email-switch-label {
- text-overflow: ellipsis;
- overflow: hidden;
- white-space: nowrap;
- }
- .primary-email-switch + label {
- align-self: stretch;
- padding: 0 5px;
- display: flex;
- align-items: center;
- }
- .controls--button {
- display: flex;
- flex-wrap: wrap;
- .controls {
- flex: 1;
- }
- .help-inline,
- .help-block {
- flex-basis: 100%;
- }
- input,
- .form-control {
- flex: 1 1 0%;
- @include bidi-style(border-right-width, 0, border-left-width, 1px);
- @include bidi-style(
- border-top-right-radius,
- 0,
- border-top-left-radius,
- 3px
- );
- @include bidi-style(
- border-bottom-right-radius,
- 0,
- border-bottom-left-radius,
- 3px
- );
- &:focus + .controls-button {
- .controls-button-inner {
- border-color: var(--border-highlight);
- }
- /*
- fake the form-control outline
- */
- &::before {
- content: '';
- position: absolute;
- left: 0;
- @include rtl(left, -3px);
- top: -3px;
- right: -3px;
- @include rtl(right, 0);
- bottom: -3px;
- background: var(--shadow-highlight);
- @include bidi-style(
- border-radius,
- 0 7px 7px 0,
- border-radius,
- 7px 0 0 7px
- );
- }
- }
- }
- }
- .controls-button {
- position: relative;
- display: flex;
- &.is-active .icon {
- fill: var(--highlight);
- }
- }
- .controls-button-inner {
- display: flex;
- justify-content: center;
- align-items: center;
- padding: 0 10px;
- background: var(--background-secondary);
- position: relative;
- border: 1px solid var(--border);
- @include bidi-style(border-radius, 0 3px 3px 0, border-radius, 3px 0 0 3px);
- .icon {
- fill: var(--text-muted);
- }
- &:hover .icon {
- fill: currentColor;
- }
- }
- .searchfield {
- position: relative;
- margin-bottom: 20px;
- .icon-magnifier,
- .search-loader {
- @include bidi-style(left, 15px, right, auto);
- top: 12px;
- width: 17px;
- height: 17px;
- position: absolute;
- fill: var(--text-muted);
- transition: 0.1s 0s;
- pointer-events: none;
- }
- .search-loader {
- z-index: 2;
- opacity: 0;
- .icon {
- width: 17px;
- height: 17px;
- }
- }
- input[type='search'] {
- appearance: textfield;
- border-radius: 19px;
- padding: 0 17px 0 42px;
- @include rtl(padding, 0 42px 0 17px);
- will-change: transform;
- &.is-empty ~ .empty-search,
- &:placeholder-shown ~ .empty-search {
- visibility: hidden;
- }
- &.loading {
- ~ .search-loader {
- opacity: 1;
- transition: 0.2s 0.5s;
- }
- ~ .icon-magnifier {
- opacity: 0;
- transition: 0.2s 0.5s;
- }
- }
- }
- input[type='search']::-webkit-search-cancel-button,
- input[type='search']::-webkit-search-decoration {
- -webkit-appearance: none;
- }
- .empty-search {
- height: 100%;
- width: 50px;
- visibility: visible;
- .icon {
- width: 13px;
- height: 13px;
- fill: var(--text-muted);
- opacity: 0.5;
- }
- }
- }
- .content {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- position: relative;
- background-color: var(--background-primary);
- @include phone {
- @include bidi-style(margin-left, $mobileNavigationWidth, margin-right, 0);
- -webkit-overflow-scrolling: touch;
- .navigation.is-not-collapsed ~ & {
- transform: translateX(
- #{$mobileNavigationWidthOpen - $mobileNavigationWidth}
- );
- @include rtl(
- transform,
- translateX(-#{$mobileNavigationWidthOpen - $mobileNavigationWidth})
- );
- }
- }
- }
- .content.fit {
- padding: 10px;
- background: var(--background-tertiary);
- z-index: 501;
- }
- .fullscreenMessage {
- padding: 22px;
- display: flex;
- align-items: center;
- justify-content: center;
- flex: 1;
- .icon {
- @include bidi-style(margin-right, 14px, margin-left, 0);
- }
- .icon-error {
- margin-top: -2px;
- width: 19px;
- height: 19px;
- }
- .icon-checkmark {
- width: 21px;
- height: 18px;
- margin-right: 11px;
- margin-top: -2px;
- }
- h2 {
- margin: 0;
- }
- }
- .fullscreenMessage--placeholder {
- flex-direction: column;
- .icon {
- width: 100px;
- height: 100px;
- }
- h2 {
- margin: 15px;
- color: var(--text-muted);
- }
- }
- .selected-clue {
- position: relative;
- @extend .zIndex-11;
- pointer-events: none;
- }
- .modal--clue {
- display: flex;
- align-items: center;
- justify-content: center;
- z-index: 500;
- .modal-backdrop {
- bottom: 0;
- width: 200%;
- height: 200%;
- left: -100%;
- top: -100%;
- background: radial-gradient(
- var(--backdrop-clue-start),
- var(--backdrop-clue-end)
- );
- }
- .modal-spacer {
- position: absolute;
- opacity: 0;
- padding: 18px;
- @extend .zIndex-11;
- }
- .modal-arrow {
- background: inherit;
- width: 20px;
- height: 20px;
- position: absolute;
- margin: -10px 0 53px -10px;
- left: 0;
- top: 50%;
- transform: rotate(45deg);
- }
- .modal-spacer[data-position='above'] .modal-arrow {
- left: 50%;
- top: 100%;
- background: var(--background-primary);
- }
- .modal-spacer[data-position='below'] .modal-arrow {
- left: 50%;
- top: 0;
- }
- .modal-spacer[data-position='left'] .modal-arrow {
- left: 100%;
- top: 50%;
- }
- .modal-content {
- border: none;
- width: 300px;
- box-shadow:
- 0 8px 17px 0 rgba(0, 0, 0, 0.1),
- 0 6px 20px 0 rgba(0, 0, 0, 0.05);
- @include phone {
- width: 280px;
- }
- }
- .modal-controls {
- background: var(--background-primary);
- margin: 23px 0 0;
- padding: 10px;
- display: flex;
- align-items: center;
- justify-content: space-between;
- }
- .modal-control {
- padding-left: 14px;
- padding-right: 14px;
- .btn.is-disabled {
- color: var(--text-normal);
- }
- }
- .modal-header {
- padding-bottom: 7px;
- font-size: 18px;
- }
- .modal-body {
- max-width: 340px;
- }
- }
- .knowledge-base-content-can-be-published-dialog-current {
- margin-bottom: 20px;
- text-align: center;
- }
- .knowledge-base-content-can-be-published-dialog {
- display: flex;
- .side-panel {
- flex-grow: 1;
- width: 300px;
- }
- .call-to-action {
- display: flex;
- align-items: center;
- justify-content: center;
- }
- }
- .kb-sidebar-block-content {
- & .kb-item--invisible {
- opacity: 0.5;
- }
- & .kb-item--missing-translation,
- & .kb-item--missing-translation:active,
- & .kb-item--missing-translation:focus {
- color: hsl(45, 98%, 63%);
- }
- }
- .kb-menu-preview {
- margin-bottom: 1em;
- &-container {
- display: flex;
- flex-wrap: wrap;
- justify-content: flex-end;
- border: 1px solid var(--border-alt);
- &--footer {
- justify-content: center;
- }
- }
- a,
- span {
- font-size: 14px;
- padding: 0.5em 1em;
- white-space: nowrap;
- text-decoration: none;
- line-height: 2em;
- }
- a {
- color: inherit;
- }
- .label {
- text-transform: none;
- }
- }
- .modified-icon {
- position: relative;
- line-height: 1;
- display: block;
- .nav-pills > li > a & {
- align-self: center;
- }
- .modified-icon-modifier {
- bottom: 0;
- right: 0;
- position: absolute;
- z-index: 1;
- fill: var(--background-primary);
- margin: 0 -2px -1px 0;
- .nav-pills > li > a & {
- fill: var(--background-secondary);
- }
- .nav-pills > li:hover > a & {
- fill: var(--background-secondary-hover);
- }
- }
- .icon-knowledge-base-answer + .modified-icon-modifier {
- margin: 0 -1px 2px 0;
- }
- .icon-published-modifier {
- display: none;
- }
- }
- kbd {
- background: var(--background-modifier-accent);
- border-radius: 3px;
- border: 1px solid var(--background-modifier-border);
- box-shadow: var(--elevation-stroke);
- display: inline-block;
- font-size: 12px;
- margin: 0 1px;
- padding: 0 4px;
- vertical-align: top;
- }
- .form-stacked .checkbox label {
- color: inherit;
- font-size: 13px;
- text-transform: inherit;
- vertical-align: baseline;
- letter-spacing: inherit;
- }
- .pagination {
- margin: 0 0 0 19px;
- @include rtl(margin, 0 19px 0 0);
- display: flex;
- }
- .pagination-counter {
- margin: 0 0 0 19px;
- @include rtl(margin, 0 19px 0 0);
- line-height: 33px;
- color: var(--text-muted);
- }
- .page-header {
- margin: 0 0 15px;
- padding: 0;
- display: flex;
- align-items: center;
- flex-wrap: wrap;
- width: 100%;
- @include phone {
- align-items: flex-start;
- flex-wrap: nowrap;
- }
- }
- .page-header--center {
- justify-content: center;
- }
- .page-header-title {
- display: flex;
- align-items: center;
- .zammad-switch {
- @include bidi-style(margin-right, 9px, margin-left, 0);
- }
- h1,
- h2 {
- margin-top: 9px;
- margin-bottom: 7px;
- @include phone {
- margin-top: 4px;
- }
- }
- .suffix {
- margin-left: 5px;
- margin-top: 6px;
- display: inline-block;
- @include phone {
- margin-top: 4px;
- }
- }
- }
- .page-header-center {
- justify-self: center;
- @include bidi-style(padding-left, 9px, padding-right, 0);
- margin: 0 auto;
- & + .page-header-meta {
- @include bidi-style(margin-left, 0, margin-right, auto);
- flex: none;
- }
- }
- .page-header-meta {
- @include bidi-style(margin-left, auto, margin-right, 0);
- @include bidi-style(padding-left, 20px, padding-right, 0);
- display: flex;
- justify-content: flex-end;
- flex: 1;
- min-width: 0; /* firefox flexbug */
- @include phone {
- flex: 0 1 auto;
- min-width: auto;
- }
- .btn {
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- @include phone {
- flex-shrink: 0;
- }
- }
- .btn + .btn {
- @include bidi-style(margin-left, 9px, margin-right, 0);
- }
- }
- .page-content {
- .formGroup-label label,
- .label {
- color: var(--header-secondary);
- }
- .content-controls-align-right {
- display: flex;
- justify-content: flex-end;
- }
- }
- .page-body--two-column {
- display: flex;
- }
- .page-aside {
- @include bidi-style(padding-right, 20px, padding-left, 0);
- @include bidi-style(border-right, 1px solid var(--border), border-left, none);
- @include bidi-style(margin-right, 20px, margin-left, 0);
- width: 240px;
- flex-shrink: 0;
- flex-grow: 0;
- }
- .page-main {
- flex: 1;
- }
- .page-loading {
- min-height: 500px;
- flex-grow: 1;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .popover .page-loading {
- min-height: 100px;
- }
- .page-loading-label {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- margin-top: 1px;
- }
- .dropdown-menu .count {
- padding-top: 1px;
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- .help-text,
- .help-block {
- color: var(--text-muted);
- }
- .help-block {
- margin: 0;
- font-size: 13px;
- &.help-block--center {
- text-align: center;
- }
- }
- .help-block:not(:empty) {
- margin: 8px 2px 0;
- }
- /* replace music icon with attachment */
- .icon-attachment {
- background-position: -24px 0;
- }
- /*
- * hero-unit (used on getstarted, login, signup)
- */
- .hero-unit {
- width: 500px;
- margin: 10px 0;
- padding: 23px 25px;
- border: 1px solid var(--border);
- color: var(--text-normal);
- background-color: var(--background-secondary);
- border-radius: 6px;
- box-shadow: var(--fullscreen-drop-shadow);
- @include phone {
- width: auto;
- padding: 12px 15px;
- }
- .inline-label {
- font-size: inherit;
- }
- }
- .hero-unit h1,
- .hero-unit h2 {
- margin-top: 0;
- }
- .getstarted,
- .reset_password,
- .request_admin_password_auth,
- .signup,
- .darkBackground,
- .login {
- padding: 10px;
- background: var(--fullscreen-background);
- }
- .content.getstarted {
- padding: 0;
- .main {
- padding: 20px 10px;
- }
- }
- .login,
- .reset_password,
- .request_admin_password_auth,
- .signup {
- padding: 24px;
- color: var(--fullscreen-text);
- a {
- color: var(--fullscreen-text-link);
- &.text-muted {
- color: inherit;
- }
- }
- }
- .login {
- .form-controls {
- flex-direction: column;
- .btn {
- width: 100%;
- }
- .btn--text {
- display: block;
- overflow: hidden;
- text-overflow: ellipsis;
- margin: initial;
- text-align: center;
- }
- .btn + .btn:not(.align-right) {
- margin-left: initial;
- margin-right: initial;
- }
- }
- .help-text {
- margin-top: 10px;
- text-align: left;
- }
- }
- .login .hero-unit {
- width: 430px;
- margin: 0 0 28px;
- @include phone {
- width: auto;
- }
- }
- .login .company-logo {
- max-height: 100px;
- max-width: 200px;
- margin: 20px auto 42px;
- display: block;
- @include phone {
- margin: 15px auto 28px;
- }
- }
- .login p,
- .reset_password p,
- .signup p {
- margin: 0 auto 22px;
- max-width: 400px;
- text-align: center;
- @include phone {
- margin: 0 auto 15px;
- }
- }
- .reset_password p,
- .signup p {
- padding-top: 28px;
- }
- .login hr {
- margin: 0 auto 22px;
- width: 100%;
- max-width: 400px;
- }
- .login p a,
- .reset_password p a,
- .signup p a {
- text-decoration: underline;
- }
- .poweredBy {
- display: flex;
- align-items: center;
- justify-content: center;
- color: var(--fullscreen-text-muted);
- margin: 34px 0 10px -16px;
- @include rtl(margin, 34px -16px 10px 0);
- cursor: default;
- a {
- color: inherit;
- }
- .icon-logo {
- @include bidi-style(margin-right, 8px, margin-left, 0);
- margin-top: -11px;
- }
- .logotype {
- @include bidi-style(margin-left, 7px, margin-left, 0);
- margin-top: -3px;
- }
- }
- .fullscreen {
- @extend .fit;
- display: flex;
- flex-direction: column;
- align-items: center;
- width: 100%;
- height: 100%;
- min-height: 100vh;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- .fullscreen p {
- color: var(--fullscreen-text);
- }
- .fullscreen-center {
- margin: auto;
- }
- .fullscreen-body {
- text-align: start;
- display: inline-block;
- }
- ol.tabs {
- list-style: decimal inside;
- }
- ol.tabs li {
- display: list-item;
- }
- .tabs {
- display: flex;
- flex-flow: wrap;
- padding: 0;
- margin-bottom: 20px;
- color: var(--interactive-muted);
- border: 1px solid var(--border);
- border-right: 0;
- border-bottom: 0;
- border-radius: 3px;
- background: var(--background-secondary);
- @include phone {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- }
- .tabs-condensed .tab {
- padding-left: 5px;
- padding-right: 5px;
- }
- .progress-tabs .tab {
- cursor: default;
- }
- .tab {
- color: inherit;
- height: 35px;
- padding: 8px 20px;
- display: flex;
- justify-content: center;
- align-items: center;
- min-width: 0;
- flex-grow: 1;
- @extend .u-clickable;
- @include phone {
- flex-shrink: 0;
- display: block;
- text-align: center;
- }
- &.active {
- color: var(--text-inverted);
- background: var(--button-active);
- box-shadow: none;
- flex-shrink: 0;
- }
- &-name {
- min-width: 20px;
- text-align: center;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- &-badge {
- flex-shrink: 0;
- @include bidi-style(margin-left, 6px, margin-right, 0);
- font-size: 13px;
- margin-right: -7px;
- background: var(--background-modifier-accent);
- min-width: 21px;
- padding: 0 7px;
- height: 21px;
- line-height: 21px;
- white-space: nowrap;
- text-align: center;
- display: inline-block;
- border-radius: 999px;
- }
- }
- .tab-dropdown {
- position: relative;
- display: flex;
- align-items: center;
- justify-content: center;
- .arrow {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- opacity: 0.75;
- }
- .icon {
- fill: var(--text-muted);
- }
- &.active {
- background: var(--background-secondary);
- .icon {
- opacity: 1;
- }
- }
- }
- .tab:nth-child(n) {
- border-right: 1px solid var(--border);
- border-bottom: 1px solid var(--border);
- }
- .tabs.tabs--inline {
- display: inline-flex;
- margin-left: 0;
- margin-right: 0;
- .tab {
- flex: none;
- &:nth-last-child(2) {
- @include bidi-style(border-right-width, 0, border-right-width, 1px);
- }
- }
- }
- .tabs--big {
- margin: 28px auto;
- font-size: 14px;
- border-radius: 8px;
- @include phone {
- margin: 5px auto 28px;
- }
- .tab {
- height: auto;
- padding: 10px 23px 9px;
- @include phone {
- padding: 8px 20px;
- }
- &:first-child {
- border-radius: 8px 0 0 8px;
- @include rtl(border-radius, 0 8px 8px 0);
- }
- &:last-child {
- border-radius: 0 8px 8px 0;
- @include rtl(border-radius, 8px 0 0 8px);
- }
- &:only-child {
- border-radius: 8px;
- }
- }
- .tab-dropdown {
- padding-left: 18px;
- padding-right: 15px;
- @include rtl(padding-left, 15px);
- @include rtl(padding-right, 18px);
- }
- }
- .dashboard .tabs--big {
- width: 50%;
- @include phone {
- width: auto;
- }
- }
- .separator {
- margin: 20px 0;
- position: relative;
- text-align: center;
- }
- .separator::before {
- content: '';
- position: absolute;
- width: 100%;
- height: 1px;
- top: 50%;
- left: 0;
- background: var(--border);
- }
- .separator-text {
- padding: 0 10px;
- color: var(--text-muted);
- font-size: 12px;
- letter-spacing: 0.05em;
- text-transform: uppercase;
- background: var(--background-secondary);
- display: inline-block;
- position: relative;
- }
- .auth-providers {
- display: flex;
- flex-wrap: wrap;
- padding: 7px;
- margin: -14px;
- > form {
- display: flex;
- flex-grow: 1;
- min-width: 50%;
- }
- }
- .auth-provider {
- height: 40px;
- padding: 0 10px 0 7px;
- margin: 7px;
- color: white !important;
- line-height: 23px;
- border-radius: 4px;
- display: flex;
- flex-grow: 1;
- justify-content: center;
- align-items: center;
- text-decoration: none;
- border: none;
- text-align: initial;
- white-space: nowrap;
- overflow: hidden;
- @extend %clickable;
- &.auth-provider--wide {
- padding-right: 25px;
- }
- &.auth-provider--facebook {
- background: #4f699c;
- }
- &.auth-provider--google {
- background: hsl(0, 0%, 93%);
- color: hsl(0, 0%, 46%) !important;
- }
- &.auth-provider--twitter {
- background: #2daee1;
- }
- &.auth-provider--email {
- background: #ffd22e;
- }
- &.auth-provider--linkedin {
- background: #006087;
- }
- &.auth-provider--github {
- background: hsl(0, 0%, 27%);
- }
- &.auth-provider--gitlab {
- background: hsl(10, 78%, 53%);
- }
- &.auth-provider--microsoft {
- background: hsl(0, 0%, 93%);
- color: hsl(0, 0%, 46%) !important;
- }
- &.auth-provider--weibo {
- background: hsl(0, 0%, 27%);
- }
- &.auth-provider--saml {
- background: hsl(0, 0%, 27%);
- }
- &.auth-provider--sso {
- background: #454545;
- }
- .provider-icon {
- width: 29px;
- height: 24px;
- flex-shrink: 0;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- .provider-name {
- overflow: hidden;
- text-overflow: ellipsis;
- }
- }
- /*
- global icon definitions
- =======================
- */
- [data-font] {
- font-style: normal;
- text-rendering: auto;
- font-feature-settings: 'liga';
- -webkit-font-smoothing: antialiased;
- -moz-osx-font-smoothing: grayscale;
- font-size: 16px;
- }
- [data-font='FontAwesome'] {
- font-size: 14px;
- }
- [data-font='material'] {
- font-size: 18px;
- }
- [data-font='ionicons'] {
- font-size: 18px;
- }
- .icon {
- fill: currentColor;
- &--md {
- width: 2rem;
- height: 2rem;
- }
- }
- [class*='icon-file-'] {
- color: var(--file-icon-background);
- fill: var(--file-icon-color);
- }
- .icon-arrow-down,
- .icon-arrow-up,
- .icon-arrow-left,
- .icon-arrow-right {
- fill: var(--text-muted);
- opacity: 0.39;
- .btn--action & {
- opacity: var(--interactive-primary);
- }
- .btn--success & {
- fill: var(--text-inverted);
- opacity: 1;
- }
- }
- .icon-arrow-left,
- .icon-arrow-right {
- &.arrow--x2 {
- width: 14px;
- height: 26px;
- }
- }
- .icon-arrow-left,
- .icon-arrow-right,
- .icon-line-left-arrow,
- .icon-line-right-arrow,
- .icon-long-arrow-right {
- @include rtl(transform, scaleX(-1));
- }
- .arrow--disabled {
- opacity: 0.23;
- }
- .icon-checkmark {
- fill: var(--supergood-color);
- }
- .icon-error {
- fill: var(--superbad-color);
- }
- .icon-danger {
- color: hsl(41, 100%, 49%);
- .alert.alert--warning & {
- color: inherit;
- }
- }
- .icon-draggable {
- opacity: 0.3;
- .table-draggable & {
- vertical-align: middle;
- cursor: move;
- }
- }
- .loading.icon {
- display: inline-block;
- width: 30px;
- height: 30px;
- background: hsl(145, 51%, 45%);
- animation: rotateplane 1.2s infinite ease-in-out;
- }
- .small.loading.icon {
- width: 20px;
- height: 20px;
- }
- .tiny.loading.icon {
- width: 12px;
- height: 12px;
- }
- .loading.icon.muted {
- background: var(--ghost-color);
- }
- @keyframes rotateplane {
- 0% {
- transform: perspective(120px) rotateX(0deg) rotateY(0deg);
- }
- 50% {
- transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
- }
- 100% {
- transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
- }
- }
- .icon-spinner-medium {
- animation: spinIcon 0.9s steps(12) infinite;
- }
- .icon-spinner-small {
- animation: spinIcon 0.9s steps(8) infinite;
- }
- @keyframes spinIcon {
- to {
- transform: rotate(-1turn);
- }
- }
- .color-swatch {
- padding: 2px;
- margin: -2px 0 -4px;
- @extend %clickable;
- /* :after technique for bigger click area */
- &::after {
- content: '';
- display: inline-block;
- height: 11px;
- width: 11px;
- border-radius: 100%;
- background: currentColor;
- }
- }
- .icon-status {
- fill: var(--ok-color);
- &.inline {
- margin-top: -3px;
- vertical-align: middle;
- }
- &.inactive {
- fill: var(--ghost-color);
- }
- &.ok {
- fill: var(--supergood-color);
- }
- &.error {
- fill: var(--superbad-color);
- }
- &.neutral {
- fill: var(--ok-color);
- }
- }
- .icon-status-modified-inner-circle {
- position: absolute;
- left: 50%;
- top: 0;
- will-change: opacity;
- transform: translate3d(-50%, 0, 0);
- animation: fade 1.8s ease-in-out infinite;
- }
- @keyframes fade {
- 54% {
- opacity: 1;
- }
- 90% {
- opacity: 0;
- }
- 100% {
- opacity: 1;
- }
- }
- .icon-checkbox,
- .icon-checkbox-checked,
- .icon-checkbox-indeterminate {
- fill: var(--text-inverted);
- }
- .icon-sso-button {
- fill: var(--text-inverted);
- }
- /*
- * removed margin of forms to not break the layout with submit buttons within <form></form> area e. g. for modal dialogs
- */
- .form {
- margin: 0;
- &--flexibleWidth .controls {
- display: table;
- }
- &--horizontal {
- display: flex;
- flex-wrap: wrap;
- align-items: flex-end;
- .alert {
- flex-basis: 100%;
- }
- fieldset {
- flex: 1 1 auto;
- margin-right: 6px;
- }
- .form-group:last-child {
- margin-bottom: 0;
- }
- .form-buttons {
- margin: 10px 10px 0 auto;
- }
- .controls {
- min-width: 250px;
- }
- }
- &--grid {
- display: flex;
- flex-wrap: wrap;
- width: calc(100% + 20px);
- margin-left: -10px;
- margin-right: -10px;
- @include phone {
- display: block;
- }
- fieldset {
- flex-basis: 100%;
- display: flex;
- flex-wrap: wrap;
- }
- .alert {
- width: 100%;
- margin-left: 10px;
- margin-right: 10px;
- margin-bottom: 10px;
- margin-top: 0;
- }
- .form-group {
- display: block;
- padding: 0 10px;
- width: 100%;
- $sizes: '1/2', '1/3', '2/3', '1/4', '2/4', '3/4', '1/5', '2/5', '3/5',
- '4/5';
- @each $size in $sizes {
- &[data-width='#{$size}'] {
- width: calc(#{$size} * 100%);
- @include phone {
- width: 100%;
- }
- }
- }
- }
- }
- }
- .form-controls {
- @extend .clearfix;
- display: flex;
- align-items: center;
- margin-top: 10px;
- .btn + .btn:not(.align-right) {
- @include bidi-style(margin-left, 20px, margin-right, 10px);
- }
- &--inline {
- margin-top: 0;
- & > * {
- @include bidi-style(margin-right, 10px, margin-left, 10px);
- }
- }
- }
- .form-buttons {
- display: flex;
- }
- form a.standalone {
- line-height: 40px;
- margin: 0 5px;
- }
- form a.standalone.align-right {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- footer {
- clear: both;
- padding-top: 10px;
- padding-left: 10px;
- padding-right: 22px;
- @include rtl(padding-left, 22px);
- @include rtl(padding-right, 10px);
- }
- .overviews {
- .sidebar {
- @include small-desktop {
- display: none;
- }
- }
- .table > tbody > tr > td {
- user-select: none;
- }
- }
- .overview-header {
- position: relative;
- margin: 20px 0 32px;
- height: 41px;
- display: none;
- align-items: center;
- @include phone {
- margin-top: 0;
- }
- .tabsHolder {
- flex: 1;
- @include bidi-style(margin-right, 20px, margin-left, 0);
- min-width: 0; /* Firefox bug fix */
- }
- .tabs {
- margin: 0;
- position: relative;
- @include phone {
- overflow: visible;
- }
- }
- .tab {
- @include phone {
- flex-shrink: 1;
- }
- }
- .tabs-clone {
- right: 0;
- }
- .dropdown {
- min-width: 0;
- width: 336px;
- @include phone {
- left: -1px;
- right: auto;
- width: calc(100vw - 70px);
- }
- }
- @include small-desktop {
- display: flex;
- }
- }
- .table-overview {
- @include phone {
- margin-left: -10px;
- margin-right: -10px;
- }
- }
- .tableOverview-edit {
- @extend .u-clickable, .u-highlight;
- }
- .bulkAction {
- position: fixed;
- bottom: 0;
- @include bidi-style(left, $sidebarWidth + $navigationWidth, right, 0);
- @include bidi-style(right, 0, left, $sidebarWidth + $navigationWidth);
- min-width: $minWidth - $sidebarWidth - $navigationWidth;
- background: var(--background-secondary);
- z-index: 1;
- box-shadow:
- 0 -1px rgba(0, 0, 0, 0.05),
- 0 -2px rgba(0, 0, 0, 0.03),
- 0 -3px rgba(0, 0, 0, 0.01);
- @include small-desktop {
- @include bidi-style(left, $navigationWidth, right, 0);
- @include bidi-style(right, 0, left, $navigationWidth);
- min-width: $minWidth - $sidebarWidth;
- }
- @include desktop {
- @include bidi-style(left, $sidebarWidth + $navigationWidth, right, 0);
- @include bidi-style(right, 0, left, $sidebarWidth + $navigationWidth);
- min-width: $minWidth - $sidebarWidth;
- }
- &.no-sidebar {
- @include bidi-style(left, $navigationWidth, right, 0);
- @include bidi-style(right, 0, left, $navigationWidth);
- min-width: $minWidth - $navigationWidth;
- @include small-desktop {
- min-width: $minWidth;
- }
- }
- @include phone {
- @include bidi-style(left, $mobileNavigationWidth, right, 0);
- @include bidi-style(right, 0, left, $mobileNavigationWidth);
- min-width: 0;
- .navigation.is-not-collapsed ~ .content & {
- @include bidi-style(left, 0, right, 0);
- }
- }
- }
- .bulkAction-firstStep {
- display: flex;
- align-items: center;
- @include phone {
- flex-direction: column;
- align-items: flex-end;
- }
- .form-group.tree_select {
- overflow: visible;
- }
- }
- .bulkAction-firstStep .has-error {
- border-color: red !important;
- border: 1px solid;
- }
- .bulkAction-secondStep {
- display: flex;
- flex-direction: column;
- &-bottom {
- display: flex;
- @include phone {
- display: block;
- }
- }
- }
- .bulkAction .btn {
- margin: 0 16px;
- @include phone {
- margin: 10px;
- }
- }
- .bulkAction .btn--text {
- @include bidi-style(margin-right, 0, margin-left, 16px);
- }
- .bulkAction-controls {
- margin-top: 10px;
- @include bidi-style(margin-left, auto, margin-right, 0);
- @include phone {
- margin-top: 0;
- display: flex;
- justify-content: space-between;
- }
- }
- .panel {
- box-shadow: none;
- background: var(--background-secondary);
- color: var(--text-normal);
- }
- .panel-default {
- border-color: var(--border-alt);
- }
- .panel-default > .panel-heading {
- padding-bottom: 8px;
- font-weight: normal;
- text-transform: uppercase;
- font-size: 12px;
- line-height: 17px;
- letter-spacing: 0.05em;
- color: inherit;
- background: var(--background-primary-alt);
- border-color: var(--border-alt);
- + .panel-collapse > .panel-body {
- border-top-color: var(--border-alt);
- }
- }
- .panel-title {
- font-size: inherit;
- }
- .panel-group .panel-heading {
- display: block;
- }
- .panel-body ul {
- list-style: none;
- padding: 0;
- margin: 0;
- }
- .well {
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 3px;
- padding: 10px;
- }
- .well-muted {
- background-color: var(--background-secondary);
- border: 1px solid rgba(0, 0, 0, 0.05);
- border-radius: 4px;
- box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
- }
- .merged,
- .merge:hover {
- text-decoration: line-through;
- }
- .translation {
- border: 1px dotted #f92;
- border-radius: 3px;
- cursor: text;
- }
- .translation[contenteditable='true'] {
- display: inline;
- }
- .translation[contenteditable='true']:hover,
- .translation[contenteditable='true']:focus {
- background: none;
- }
- .translation .icon-edit {
- display: none;
- }
- .translation:hover .icon-edit {
- display: inline-block;
- }
- .translationOverview .btn + .btn {
- margin: -10px;
- }
- .sub_attribute .control-label {
- width: 60px;
- }
- .sub_attribute .controls {
- @include bidi-style(margin-left, 80px, margin-right, 0);
- }
- .splash {
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- background: var(--background-primary);
- display: flex;
- align-items: center;
- justify-content: center;
- font-size: 16px;
- color: var(--text-normal);
- .icon {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- }
- .navigation {
- width: $navigationWidth;
- background: var(--menu-background-primary);
- border: var(--menu-border);
- position: relative;
- container-name: navigation;
- container-type: inline-size;
- @include phone {
- position: absolute;
- @include bidi-style(left, 0, right, auto);
- top: 0;
- left: 0;
- width: $mobileNavigationWidth;
- height: 100%;
- z-index: 999;
- &:empty {
- display: none !important;
- }
- &.is-not-collapsed {
- width: $mobileNavigationWidthOpen;
- .menu-item-name {
- display: block;
- padding-left: 15px;
- }
- }
- }
- }
- @container navigation (width = 50px) {
- .icon-double-arrow-left {
- display: none;
- }
- }
- @container navigation (width > 50px) {
- .icon-double-arrow-right {
- display: none;
- }
- }
- .menu {
- padding: 0;
- margin: 0;
- list-style: none;
- flex-shrink: 0;
- }
- .menu .badge {
- background: var(--ok-color);
- color: hsl(233, 10%, 16%);
- @include bidi-style(margin-right, 8px, margin-left, 0);
- }
- .menu .zammad-switch {
- height: 22px;
- }
- .menu .dropdown-menu {
- left: 10px;
- right: 15px;
- min-width: 0;
- }
- .menu-item {
- padding: 0 15px;
- height: 48px;
- color: var(--menu-text);
- border-bottom: 1px solid hsla(230, 4%, 84%, 0.05);
- text-decoration: none;
- display: flex;
- align-items: center;
- @extend %clickable;
- @include phone {
- padding: 0 13px;
- position: relative;
- }
- .icon {
- fill: var(--menu-icon);
- &.accessory-icon {
- opacity: 0.7;
- }
- }
- &:hover {
- background: var(--menu-background-primary-hover);
- border-bottom-color: hsla(230, 4%, 84%, 0.1);
- }
- &.is-active,
- &.is-hovered {
- background: var(--menu-background-active);
- color: var(--menu-text-active);
- }
- &.is-active .menu-item-icon,
- &.is-active .dropdown-icon,
- &.is-hovered .menu-item-icon {
- fill: currentColor;
- }
- &.is-active .zammad-switch {
- input:not(:checked) + label {
- // switch background
- background: var(--button-primary-background-active);
- }
- label::after {
- background: var(--menu-switch-pointer-active);
- }
- }
- .dropdown-icon {
- fill: currentColor;
- }
- .zammad-switch {
- @include phone {
- .navigation:not(:hover, :active, .is-not-collapsed) & {
- position: absolute;
- right: 12px;
- top: 12px;
- width: auto;
- height: auto;
- border-radius: 0;
- input:checked + label {
- background: var(--supergood-color);
- }
- label {
- width: 8px;
- height: 8px;
- background: red;
- border-radius: 100%;
- transition: none;
- &::after {
- display: none;
- }
- }
- }
- }
- }
- &-navigation-toggle-button {
- justify-content: center;
- border-top: 1px solid rgba(213, 213, 216, 0.05);
- border-bottom: none;
- @include desktop {
- display: none;
- }
- @container navigation (width > 50px) {
- justify-content: flex-end;
- }
- }
- }
- .menu-item-icon {
- @include bidi-style(margin-right, 15px, margin-left, 0);
- width: 24px;
- height: 24px;
- @include phone {
- @include bidi-style(margin-right, 0, margin-left, 0);
- }
- }
- .menu-item-name {
- flex: 1;
- margin-top: 2px;
- @include phone {
- display: none;
- }
- }
- .call-widgets {
- overflow-y: auto;
- max-height: 30vh;
- }
- .call-widget {
- background: var(--background-quaternary-alt);
- padding: 8px 10px;
- & + & {
- border-top: 1px solid var(--background-modifier-border);
- }
- &-header {
- display: flex;
- color: inherit;
- margin-bottom: 3px;
- .label {
- color: inherit;
- margin: 0;
- }
- .btn--text {
- color: inherit;
- opacity: 0.5;
- &:hover {
- opacity: 1;
- }
- }
- .icon-diagonal-cross {
- width: 9px;
- height: 9px;
- margin-top: -5px;
- }
- }
- }
- .tasks {
- background: var(--menu-background-secondary);
- border-right: var(--menu-border-secondary);
- flex: 1;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- @include phone {
- overflow-x: hidden;
- min-height: 60px;
- }
- }
- .tasks.tasks--standalone {
- background: none;
- margin: 8px 0 0;
- padding: 0;
- overflow: visible;
- }
- .tasks--standalone .task {
- padding: 0;
- margin-bottom: 9px;
- display: flex;
- .icon-holder {
- &:first-child .icon-task-state {
- margin-left: -2px;
- }
- .icon {
- width: 16px;
- height: 16px;
- vertical-align: middle;
- margin-top: -3px;
- @include bidi-style(margin-right, 4px, margin-left, 0);
- }
- }
- }
- .tasks--standalone .task-text {
- flex: 1;
- min-width: 0; /* Firefox wrong content-calculation with word-wrap workaround */
- }
- .tasks--standalone .task-id {
- &::after {
- content: ' - ';
- }
- }
- .tasks--standalone .name {
- @extend .u-highlight, .u-textTruncate;
- display: block;
- }
- .tasks--standalone .time {
- color: var(--text-muted);
- }
- .tasks--standalone .btn-show-all {
- margin-bottom: 9px;
- }
- .nav-tab {
- @include bidi-style(padding, 10px 15px 9px 0, padding, 10px 0 9px 15px);
- position: relative;
- color: var(--menu-text);
- display: flex;
- align-items: center;
- @extend .u-clickable;
- @include phone {
- width: $mobileNavigationWidthOpen;
- }
- }
- .tasks-navigation .nav-tab {
- height: 40px;
- border-bottom: 1px solid hsla(230, 4%, 84%, 0.05);
- }
- .tasks-navigation .nav-tab:not(.is-active):hover {
- background: var(--menu-background-primary);
- border-bottom-color: hsla(230, 4%, 84%, 0.1);
- }
- .navigation .nav-tab-name {
- text-align: start;
- &.is-inactive {
- text-decoration: line-through;
- opacity: 0.73;
- }
- }
- .tasks-navigation .nav-tab-icon .error {
- transform: scale(0.85);
- }
- .nav-tab.is-active,
- .nav-tab.nav-tab--search:hover,
- .nav-tab.nav-tab--search.is-hover {
- background: var(--menu-background-active);
- color: var(--menu-text-active);
- .nav-tab-icon .icon {
- fill: currentColor;
- }
- }
- .nav-tab.ui-sortable-helper {
- border-bottom-color: transparent;
- }
- .nav-tab.nav-tab--search {
- height: 30px;
- padding-top: 9px;
- &.is-inactive {
- text-decoration: line-through;
- opacity: 0.73;
- }
- }
- .nav-tab-icon {
- margin-top: -3px;
- display: flex;
- align-items: center;
- justify-content: center;
- position: relative;
- width: 30px;
- }
- .nav-tab-icon .icon {
- max-width: 18px;
- max-height: 18px;
- fill: var(--nav-icon);
- }
- .nav-tab-icon .icon-diagonal-cross {
- fill: #f35910;
- width: 12px;
- height: 12px;
- }
- .nav-tab-icon .icon.icon-loading {
- animation: rotateplane 1.2s infinite ease-in-out;
- fill: var(--supergood-color);
- /*
- Safari font rendering bugfix while animating
- http://stackoverflow.com/questions/9733011/safari-changing-font-weights-when-unrelated-animations-are-running
- */
- @extend .zIndex-5; // stay beneath .global-search-menu
- position: relative;
- }
- .nav-tab-close {
- position: absolute;
- @include bidi-style(right, 0, left, auto);
- top: 0;
- height: 100%;
- @include bidi-style(padding-right, 16px, padding-left, 0);
- visibility: hidden;
- @extend .u-clickable;
- display: flex;
- align-items: center;
- @include phone {
- visibility: visible;
- }
- }
- .nav-tab:hover .nav-tab-close {
- visibility: visible;
- }
- .nav-tab-close-inner {
- width: 19px;
- height: 19px;
- background-color: var(--menu-close-tab-background);
- border-radius: 100%;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .nav-tab-close:hover .nav-tab-close-inner {
- background-color: #972e29;
- }
- .nav-tab-close svg {
- width: 9px;
- height: 9px;
- fill: var(--text-inverted);
- opacity: var(--menu-close-tab-opacity);
- }
- .nav-tab-close:hover svg {
- opacity: 1;
- }
- .icon-task-state {
- vertical-align: middle;
- }
- .nav-tab-icon .icon-task-state {
- margin: 0;
- }
- .nav-tab.task-state-open.is-active {
- background-color: var(--ok-color);
- color: var(--menu-text-open);
- }
- .task-state-open-color {
- color: var(--ok-color);
- }
- .icon-task-state.open {
- fill: var(--ok-color);
- }
- .nav-tab.task-state-closed.is-active {
- background-color: var(--supergood-color);
- color: var(--menu-text-closed);
- }
- .task-state-closed-color {
- color: var(--supergood-color);
- }
- .icon-task-state.closed {
- fill: var(--supergood-color);
- }
- .nav-tab.task-state-escalating.is-active {
- background-color: var(--superbad-color);
- color: var(--menu-text-escalating);
- }
- .task-state-escalating-color {
- color: var(--superbad-color);
- }
- .icon-task-state.escalating {
- fill: var(--superbad-color);
- }
- // TODO: rename to knowledgebase icon when it's available
- .icon-task-state.archived {
- fill: var(--superbad-color);
- }
- .icon-task-state.published {
- fill: var(--supergood-color);
- }
- .icon-task-state.draft {
- fill: var(--ghost-color);
- }
- // pending: stays blue
- // .nav-tab.task-state-pending.is-active {
- // background-color: var(--pending-color);
- // }
- .task-state-pending-color {
- color: var(--text-muted);
- }
- .icon-task-state.pending {
- fill: var(--pending-color);
- }
- .state-badge {
- display: flex;
- align-items: center;
- .icon-task-state {
- @include bidi-style(margin-right, 2px, margin-left, 0);
- }
- }
- .search {
- padding: 11px 5px 4px 10px;
- @include rtl(padding, 11px 10px 4px 0);
- border-bottom: 1px solid rgba(240, 250, 255, 0.05);
- flex-shrink: 0;
- display: flex;
- align-items: flex-start;
- background-color: inherit;
- @include phone {
- padding: 10px 5px 5px;
- @include rtl(padding, 10px 5px 5px);
- display: block;
- }
- }
- .search-holder {
- flex: 1;
- border-radius: 15px;
- position: relative;
- transition: margin-right 120ms;
- will-change: margin-right;
- @include phone {
- transition: none;
- will-change: initial;
- }
- }
- .empty-search {
- position: absolute;
- @include bidi-style(right, 0, left, auto);
- top: 0;
- height: 30px;
- width: 40px;
- z-index: 1;
- visibility: hidden;
- display: flex;
- align-items: center;
- justify-content: center;
- @extend %clickable;
- }
- .search .empty-search .icon-diagonal-cross {
- fill: var(--text-inverted);
- opacity: 0.5;
- }
- .filled.search .empty-search {
- visibility: visible;
- }
- .search input[type='search'] {
- width: 100%;
- padding: 5px 33px;
- height: 30px;
- color: var(--menu-text);
- background: var(--menu-background-secondary);
- line-height: 20px;
- outline: none;
- border: none;
- border-radius: 15px;
- position: relative;
- z-index: 1;
- appearance: textfield;
- @include phone {
- padding: 5px 33px;
- font-size: 16px;
- }
- }
- .navigation:not(.is-not-collapsed)
- .search:not(.filled, .focused)
- input[type='search'] {
- @include phone {
- padding: 0;
- }
- }
- input[type='search']::-webkit-search-cancel-button,
- input[type='search']::-webkit-search-decoration {
- -webkit-appearance: none;
- }
- .search .search-loader {
- position: absolute;
- top: 8px;
- left: 10px;
- z-index: 2;
- opacity: 0;
- transition: 0.1s 0s;
- pointer-events: none;
- .icon {
- fill: var(--text-inverted);
- opacity: 0.5;
- }
- }
- .search.loading .search-loader {
- opacity: 1;
- transition: 0.2s 0.5s;
- }
- .search .icon-magnifier {
- position: absolute;
- top: 8px;
- left: 10px;
- @include bidi-style(left, 10px, right, auto);
- z-index: 2;
- fill: var(--menu-icon);
- transition: opacity 0.1s;
- pointer-events: none;
- }
- .search.loading .icon-magnifier {
- opacity: 0;
- transition: 0.2s 0.5s;
- }
- .search.focused .search-holder {
- transition: margin-right 240ms;
- @include bidi-style(margin-right, -59px, margin-left, 0);
- @include phone {
- margin: 0 !important;
- }
- }
- .search.focused .logo {
- opacity: 0;
- z-index: -1;
- @include phone {
- opacity: 1;
- z-index: initial;
- }
- }
- .search.filled {
- .search-holder {
- @include phone {
- .navigation:not(:hover, :active, .is-not-collapsed) & {
- width: 210px;
- }
- }
- }
- .logo {
- @include phone {
- opacity: 0;
- }
- }
- }
- .search .logo {
- display: inline-block;
- position: relative;
- @extend .u-clickable, .zIndex-3;
- margin: -4px 10px 0 12px;
- transition: 240ms;
- @include phone {
- margin: 10px 0 0;
- }
- }
- .search .logo .icon-logo {
- position: relative;
- @include phone {
- width: 35px;
- height: 30px;
- margin-left: 4px;
- }
- }
- .search .logo .activity-counter {
- min-width: 21px;
- position: absolute;
- right: -3px;
- bottom: 2px;
- padding: 0 4px;
- font-size: 12px;
- font-weight: 300;
- line-height: 16px;
- text-align: center;
- color: var(--text-inverted);
- text-shadow: 0 1px 1px rgba(0, 0, 0, 0.21);
- background: hsl(360, 71%, 60%);
- border-radius: 10px;
- border: 2px solid var(--menu-background-primary);
- }
- .search .logo .activity-counter:empty {
- display: none;
- }
- .global-search-menu {
- @extend .zIndex-7;
- background: var(--menu-background-primary);
- position: absolute;
- left: 0;
- right: 0;
- bottom: 0;
- top: 53px;
- display: none;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- .divider {
- height: 1px;
- background: var(--menu-background-secondary);
- margin: 14px 0 17px;
- }
- }
- .search.open .global-search-menu {
- display: block;
- }
- .global-search-detail-link {
- padding: 9px 15px 8px 0;
- margin-bottom: 7px;
- height: auto !important;
- .no-match & {
- display: none;
- }
- .nav-tab-icon {
- width: 18px;
- margin-left: 10px;
- margin-right: 10px;
- .icon {
- width: 18px;
- height: 14px;
- }
- }
- .nav-tab-name {
- .icon {
- fill: currentColor;
- margin: -2px 0 0 3px;
- vertical-align: middle;
- }
- }
- }
- .global-search-result {
- margin: 0;
- padding: 0;
- list-style: none;
- }
- .global-search-detail-no-result {
- margin: 0 10px;
- .icon {
- width: 30px;
- height: 29px;
- }
- }
- .user-menu {
- padding: 0;
- margin: 0;
- list-style: none;
- position: relative;
- flex-shrink: 0;
- display: flex;
- @include phone {
- flex-direction: column;
- }
- }
- .user-menu > li {
- flex: 1;
- background: var(--menu-background-primary);
- }
- .user-menu .list-button {
- height: 60px;
- position: relative;
- text-decoration: none;
- @extend .u-clickable;
- display: flex;
- align-items: center;
- justify-content: center;
- @include phone {
- height: 46px;
- }
- }
- .user-menu .list-button *:not(.dropdown-nose, .icon-crown),
- .user-menu .list-button *:not(.dropdown-nose, .icon-crown-silver) {
- position: relative;
- }
- .user-menu > li:hover .list-button::before,
- .user-menu > li.open .list-button::before,
- .user-menu > li.is-active .list-button::before,
- .user-menu > li.is-hovered .list-button::before {
- content: '';
- position: absolute;
- top: 4px;
- right: 4px;
- bottom: 4px;
- left: 4px;
- background: var(--menu-icon-secondary-hover-background);
- }
- .user-menu > li.is-active .list-button::before {
- background: var(--highlight);
- }
- .user-menu li.add:hover .list-button::before,
- .user-menu li.add.is-active .list-button::before,
- .user-menu li.add.is-hovered .list-button::before {
- background: #38ae6a;
- }
- .user-menu-icon {
- width: 20px;
- height: 20px;
- fill: var(--menu-icon-secondary);
- }
- .user-menu-icon.icon-plus {
- fill: hsl(145, 51%, 45%);
- }
- .user-menu > li:hover .user-menu-icon {
- fill: var(--menu-background-primary);
- }
- .user-menu > li.is-active .user-menu-icon {
- fill: var(--text-inverted);
- }
- .user-menu > li.add:hover .user-menu-icon.icon-plus,
- .user-menu > li.add.is-hovered .user-menu-icon.icon-plus,
- .user-menu > li.add.is-active .user-menu-icon.icon-plus {
- fill: var(--text-inverted);
- }
- .user-menu > li:not(:last-child) {
- border-right: 1px solid var(--background-modifier-accent);
- @include phone {
- border: none;
- }
- }
- .dropdown-nose {
- position: absolute;
- border: 7px solid transparent;
- border-bottom: none;
- border-top: 7px solid var(--background-secondary);
- left: 50%;
- margin-left: -7px;
- top: -6px;
- display: none;
- }
- li.add .dropdown-nose {
- border-top-color: #38af6e;
- }
- .open.dropdown .dropdown-nose,
- .open.dropup .dropdown-nose {
- display: block;
- }
- .user-menu .dropdown-menu {
- padding: 0;
- border-radius: 0;
- margin-bottom: 5px;
- min-width: 0;
- left: 10px;
- right: 15px;
- width: 235px;
- box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.28);
- &.selected-clue {
- position: absolute;
- }
- }
- .user-menu li.add .dropdown-menu {
- background-color: #38af6e;
- }
- .user-menu li.add .dropdown-menu li > a {
- color: var(--text-inverted);
- }
- .user-menu li.add .dropdown-menu .divider {
- background: #4cb77c;
- }
- .user-menu .dropdown-menu .divider {
- margin: 0;
- }
- .user-menu .dropdown-menu > li > a {
- display: flex;
- }
- .avatar {
- width: 40px;
- height: 40px;
- background-size: cover;
- background-position: center;
- border-radius: 100%;
- display: inline-block;
- vertical-align: bottom;
- position: relative;
- flex-shrink: 0;
- @include phone {
- width: 30px;
- height: 30px;
- }
- a {
- color: inherit;
- }
- &.size-30 {
- width: 30px;
- height: 30px;
- @include phone {
- width: 22px;
- height: 22px;
- }
- }
- .icon-crown,
- .icon-crown-silver {
- position: absolute;
- width: 28px;
- left: 50%;
- margin-left: -14px;
- top: -15px;
- @include phone {
- width: 20px;
- margin-left: -10px;
- }
- }
- .icon-crown {
- fill: hsl(47, 100%, 59%);
- }
- &-status {
- position: absolute;
- right: -4px;
- bottom: -4px;
- border-radius: 999px;
- background: var(--background-tertiary);
- fill: var(--text-inverted);
- width: 21px;
- height: 21px;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- &.size-50 {
- width: 50px;
- height: 50px;
- @include phone {
- width: 36px;
- height: 36px;
- }
- .icon-crown,
- .icon-crown-silver {
- width: 36px;
- margin-left: -18px;
- @include phone {
- width: 26px;
- margin-left: -13px;
- }
- }
- }
- &.size-80 {
- width: 82px;
- height: 82px;
- @include phone {
- width: 60px;
- height: 60px;
- }
- .icon-crown,
- .icon-crown-silver {
- width: 64px;
- margin-left: -32px;
- top: -16px;
- @include phone {
- width: 46px;
- margin-left: -43px;
- top: -15px;
- }
- }
- }
- &--vacation {
- filter: grayscale(70%);
- opacity: 1;
- }
- &--idle {
- filter: grayscale(100%);
- opacity: 0.5;
- }
- &--inactive {
- filter: grayscale(100%);
- opacity: 0.2;
- }
- &--organization {
- background: var(--background-modifier-accent);
- color: var(--text-muted);
- }
- &--unique {
- background-image: image_url('/assets/images/avatar-bg.png');
- background-size: 300px 226px;
- color: var(--text-inverted);
- line-height: 40px;
- text-align: center;
- font-size: 13px;
- letter-spacing: 0.05em;
- text-transform: uppercase;
- text-shadow: 0 1px rgba(0, 0, 0, 0.2);
- @include phone {
- line-height: 30px;
- }
- &.size-30 {
- font-size: 10px;
- line-height: 32px;
- background-size: 225px 170px;
- @include phone {
- line-height: 22px;
- }
- }
- &.size-50 {
- font-size: 16px;
- line-height: 52px;
- background-size: 375px 283px;
- @include phone {
- line-height: 38px;
- }
- }
- &.size-80 {
- font-size: 26px;
- line-height: 84px;
- background-size: 600px 452px;
- @include phone {
- line-height: 62px;
- }
- }
- }
- &--not-linked {
- cursor: default;
- }
- &--organization {
- display: flex;
- align-items: center;
- justify-content: center;
- .icon-organization {
- fill: currentColor;
- }
- &.size-80 {
- .icon-inactive-organization,
- .icon-organization {
- width: 32px;
- height: 32px;
- }
- }
- }
- &--group {
- overflow: hidden;
- .icon {
- fill: var(--text-inverted);
- position: absolute;
- left: 50%;
- transform: translateX(-50%);
- width: 44px;
- height: 44px;
- bottom: -8px;
- }
- &.size-30 .icon {
- width: 33px;
- height: 33px;
- bottom: -6px;
- }
- &.size-50 .icon {
- width: 55px;
- height: 55px;
- bottom: -10px;
- }
- &.size-80 .icon {
- width: 88px;
- height: 88px;
- bottom: -15px;
- }
- &-color-0 {
- background: hsl(192, 100%, 38%);
- }
- &-color-1 {
- background: hsl(148, 100%, 38%);
- }
- &-color-2 {
- background: hsl(57, 100%, 37%);
- }
- }
- .icon-logo {
- width: 100%;
- height: 100%;
- }
- }
- .sidebar {
- position: relative;
- width: 280px;
- padding: 20px;
- color: var(--text-normal);
- background: var(--background-secondary);
- @include bidi-style(border-right, 1px solid var(--border), border-left, none);
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- @include small-desktop {
- &.optional {
- display: none;
- }
- }
- h2 {
- margin-top: 0;
- }
- h3 {
- margin: 0;
- font-weight: normal;
- font-size: 16px;
- text-transform: initial;
- letter-spacing: 0;
- }
- }
- .sidebar-block {
- margin: 20px 0;
- &:first-child {
- margin-top: 0;
- }
- &-actions {
- margin-bottom: 7px;
- }
- &-header {
- margin-bottom: 7px;
- h2 {
- margin: 0;
- }
- }
- [contenteditable='true'] {
- white-space: normal; // do no u-textTruncate, we want to edit it inline
- }
- .btn-list {
- margin-bottom: 5px;
- }
- &-button {
- .sidebar-block-header + &.text-muted {
- margin-top: 3px;
- }
- }
- }
- .sidebar-git-issue-delete {
- text-align: right;
- @include rtl(text-align, left);
- float: right;
- @include rtl(float, left);
- }
- .sidebar-git-issue-content {
- width: 90%;
- }
- .main + .sidebar {
- border-right: none;
- border-left: 1px solid var(--border);
- @include dark {
- border-left: none;
- }
- }
- .NavBarAdmin.sidebar,
- .NavBarProfile.sidebar {
- width: $sidebarWidth;
- @include phone {
- width: 50px;
- padding-left: 10px;
- padding-right: 10px;
- &:hover,
- &:active {
- width: 165px;
- padding-left: 15px;
- padding-right: 15px;
- }
- }
- h2 {
- margin: 21px 0 12px;
- @include phone {
- white-space: nowrap;
- }
- }
- h2:first-child {
- margin-top: 0;
- }
- }
- .nav-stacked > li + li {
- margin-top: 0;
- }
- .nav-pills > li > a,
- .nav-pills > li > a:focus,
- .nav-pills > li > a:active,
- .nav-pills .nav-pills-placeholder {
- color: var(--text-nav);
- border-radius: 0;
- background: transparent; /* a:focus, a:active with bg: transparent fixes gray focus bg in IE 10 */
- display: flex;
- @extend .u-textTruncate;
- }
- .nav-pills.nav-stacked > li > a,
- .nav-pills.nav-stacked > li > a:focus,
- .nav-pills.nav-stacked > li > a:active,
- .nav-pills.nav-stacked .nav-pills-placeholder {
- padding: 0;
- height: 40px;
- line-height: 39px;
- border-top: 1px solid var(--background-modifier-border);
- }
- .nav-pills.nav-stacked .nav-pills-placeholder {
- display: block;
- border-top: none;
- @extend .label-subtle;
- @extend .u-textTruncate;
- }
- .nav-pills > li:hover > a {
- background: var(--background-secondary-hover);
- }
- .nav-pills.nav-stacked > li:hover > a,
- .nav-pills.nav-stacked > li.active + li:not(.active) > a,
- .nav-pills.nav-stacked > li:hover + li:not(.active) > a {
- border-color: transparent;
- }
- .nav-pills > li.active > a,
- .nav-pills > li.active > a:hover,
- .nav-pills > li.active > a:focus {
- color: var(--text-active);
- background: var(--background-active);
- border-color: var(--background-modifier-border);
- }
- .nav-pills.nav-stacked > li:hover > a,
- .nav-pills.nav-stacked > li.active > a,
- .nav-pills.nav-stacked > li.active > a:hover,
- .nav-pills.nav-stacked > li.active > a:focus {
- padding-left: 10px;
- padding-right: 10px;
- margin-left: -10px;
- margin-right: -10px;
- }
- .sidebar:not(.NavBarAdmin) .nav-pills > li:first-child > a {
- border-top: none;
- }
- .nav-pills > li > a > .icon {
- fill: currentColor;
- flex-shrink: 0;
- align-self: center;
- margin-top: -2px;
- &:first-child {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- &[data-font] {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- @include bidi-style(margin-left, 5px, margin-right, 0);
- }
- }
- }
- .nav-pills > li > a > .badge {
- margin-left: auto;
- margin-right: 5px;
- @include bidi-style(padding-left, 10px, padding-right, 0);
- @include rtl(margin-left, 5px);
- @include rtl(margin-right, auto);
- }
- a.list-group-item.active > .badge,
- .nav-pills > .active > a > .badge {
- color: var(--text-active);
- background: none;
- }
- .main {
- padding: 10px 20px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- position: relative;
- @include phone {
- padding: 10px;
- }
- &--large-padding {
- padding: 30px 40px;
- }
- }
- .main--tabs,
- .main.no-padding {
- padding: 0;
- }
- .tooltip {
- font-family: inherit;
- }
- .tooltip-inner {
- max-width: 400px;
- }
- .popover {
- @extend .zIndex-12;
- position: absolute;
- font-family: inherit;
- width: 372px;
- max-width: 9999px;
- border-radius: 0;
- margin: 0 5px;
- background: var(--background-popover);
- border: none;
- box-shadow: var(--elevation-high);
- @include rtl(text-align, right);
- @include phone {
- width: auto;
- }
- > .arrow::after {
- border-color: var(--background-popover);
- }
- }
- .popover--has-horizontal-form {
- width: auto;
- }
- .popover-body {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- .popover-title {
- display: flex;
- align-items: center;
- border: none;
- background: none;
- padding: 21px 17px 4px;
- .is-inactive {
- text-decoration: line-through;
- color: var(--interactive-muted);
- }
- h2 {
- margin: 0;
- }
- .popover-avatar {
- @include bidi-style(margin-right, 8px, margin-left, 0);
- }
- .popover-headline {
- display: flex;
- flex-direction: column;
- }
- }
- .popover-content {
- padding: 0 17px;
- margin-bottom: 21px;
- .popover--has-horizontal-form & {
- padding: 10px 5px 15px 15px;
- margin-bottom: 0;
- }
- }
- .popover.right {
- margin-left: 4px;
- }
- .popover.right > .arrow {
- border-right: none;
- left: -9px;
- }
- .popover.top {
- margin-bottom: 9px;
- }
- .popover.top > .arrow {
- border-top: none;
- bottom: -9px;
- }
- .popover.left {
- margin-right: 9px;
- margin-left: 0;
- }
- .popover.left > .arrow {
- border-left: none;
- right: -9px;
- }
- .popover.bottom {
- margin-top: 9px;
- }
- .popover.bottom > .arrow {
- border-bottom: none;
- top: -9px;
- }
- .popover > .arrow::after {
- border-width: 8px;
- }
- .popover .priority.icon::after {
- background: var(--background-secondary);
- }
- .popover .person .organization {
- color: var(--text-muted);
- }
- .popover .person {
- &.is-inactive {
- text-decoration: line-through;
- color: var(--ghost-color);
- }
- }
- .popover .user-organization {
- @extend .u-textTruncate;
- &.is-inactive {
- text-decoration: line-through;
- color: var(--ghost-color);
- }
- }
- .popover-block {
- @extend .sidebar-block;
- margin: 10px 0;
- }
- .popover hr {
- margin: 8px 0;
- }
- .popover .person .organization::before {
- content: '(';
- }
- .popover .person .organization::after {
- content: ')';
- }
- .popover label {
- font-size: 13px;
- color: var(--header-secondary);
- font-weight: 300;
- text-transform: uppercase;
- letter-spacing: 0.05em;
- }
- .popover .two-columns,
- .popover .three-columns {
- margin-top: -8px;
- }
- .popover .column label {
- margin: 8px 0 1px;
- }
- .popover .column {
- margin-top: 8px;
- }
- .popover--notifications {
- padding: 0;
- left: $navigationWidth;
- @include rtl(right, $navigationWidth);
- margin: 8px 2px;
- max-height: calc(100% - 16px);
- width: auto;
- max-width: 400px;
- min-width: 350px;
- flex-direction: column;
- @extend .zIndex-10;
- @include phone {
- left: $mobileNavigationWidth;
- @include rtl(right, $mobileNavigationWidth);
- min-width: auto;
- width: calc(100% - #{$mobileNavigationWidth} - 8px);
- }
- &.is-visible {
- display: flex;
- }
- &.is-empty .popover-notificationsHeader {
- box-shadow: none;
- }
- .arrow {
- top: 23px !important;
- left: -11px;
- @include rtl(left, 408px);
- @include rtl(transform, rotate(180deg));
- @include phone {
- top: 61px !important;
- }
- }
- .popover-content {
- padding-left: 0;
- padding-right: 0;
- margin-bottom: 0;
- overflow-y: auto;
- }
- .popover-notificationsHeader {
- border-bottom: 1px solid var(--background-modifier-accent);
- padding-bottom: 14px;
- flex-shrink: 0;
- .btn {
- padding-top: 3px;
- padding-bottom: 5px;
- }
- }
- .activity-placeholder {
- margin-bottom: 21px;
- }
- }
- .popover-notificationsHeader {
- padding-bottom: 8px;
- margin: 21px 17px 0;
- .popover-title {
- @extend h1;
- padding: 0;
- line-height: 1;
- }
- .btn {
- margin-top: 3px;
- }
- }
- .popover-notificationsCounter {
- color: #e25253;
- @include bidi-style(padding-left, 3px, padding-right, 0);
- }
- .user-popover,
- .ticket-popover,
- .organization-popover {
- @extend .u-clickable;
- }
- .user-card {
- padding: 2px 0 0 50px;
- position: relative;
- min-height: 40px;
- padding-right: 48px;
- display: flex;
- flex-direction: column;
- justify-content: center;
- min-width: 192px;
- .avatar {
- position: absolute;
- left: 0;
- top: 0;
- }
- .user-popover.is-inactive {
- text-decoration: line-through;
- opacity: 0.73;
- }
- .btn.js-newTicket {
- position: absolute;
- right: 0;
- }
- }
- .stat-icon {
- position: relative;
- }
- .mood-icon {
- width: 60px;
- height: 59px;
- }
- .stopwatch-icon {
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- }
- .stat-stopwatch {
- width: 77px;
- height: 83px;
- position: relative;
- }
- .stat-channel-icon {
- width: 16px;
- height: 16px;
- fill: var(--text-muted);
- }
- .total-tickets {
- height: 83px;
- width: 48px;
- @include bidi-style(margin-right, 4px, margin-left, 0);
- margin-bottom: -9px;
- fill: hsl(196, 19%, 89%);
- color: var(--background-secondary);
- @include dark {
- fill: hsl(196, 9%, 70%);
- }
- }
- .one-ticket {
- width: 48px;
- height: 10px;
- margin-top: -7px;
- margin-bottom: 2px;
- position: relative;
- }
- .stat-tickets {
- height: 100px;
- color: var(--background-secondary);
- }
- .in-process-icon {
- width: 64px;
- height: 64px;
- }
- .reopening-icon {
- width: 68px;
- height: 47px;
- }
- .supergood-color {
- fill: var(--supergood-color);
- }
- .good-color {
- fill: var(--good-color);
- }
- .ok-color {
- fill: var(--ok-color);
- }
- .bad-color {
- fill: var(--bad-color);
- }
- .superbad-color {
- fill: var(--superbad-color);
- }
- .danger-color {
- color: var(--danger-color);
- }
- .u-high-priority-color {
- fill: $high-priority-color;
- }
- .u-low-priority-color {
- fill: $low-priority-color;
- }
- .stat-widgets {
- margin: -7px -7px 20px;
- }
- .stat-widget {
- height: 200px;
- padding: 10px 10px 8px;
- text-align: center;
- line-height: 20px;
- }
- .dashboard .stat-widget {
- margin: 7px;
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 1px;
- box-shadow: var(--elevation-low);
- }
- .stat-title {
- font-size: 13px;
- margin: 2px 0 8px;
- text-transform: uppercase;
- font-weight: normal;
- position: relative;
- padding: 0 24px;
- .tooltip {
- text-transform: none;
- width: 200px;
- }
- }
- .stat-icon-help {
- position: absolute;
- right: 3px;
- top: 1px;
- cursor: help;
- fill: var(--interactive-muted);
- }
- .notification-icon-help {
- fill: var(--interactive-muted);
- }
- .stat-label {
- @extend .u-textTruncate;
- }
- .stat-detail {
- color: var(--text-muted);
- @extend .u-textTruncate;
- }
- .stat-graphic {
- flex: 1;
- display: flex;
- justify-content: center;
- align-items: center;
- user-select: none;
- }
- .time.stat-widget .stat-amount {
- margin-top: 12px;
- text-align: center;
- font-size: 30px;
- color: var(--text-inverted);
- text-shadow: 0 2px rgba(0, 8, 14, 0.2);
- position: relative;
- cursor: default;
- }
- .time.stat-widget .stat-dial {
- position: absolute;
- top: 21px;
- left: 14px;
- width: 52px;
- height: 52px;
- }
- .stats-row {
- padding: 8px 0 7px;
- border-radius: 3px;
- display: flex;
- flex-direction: column;
- align-items: center;
- flex: 0 1 38px;
- height: 100%;
- .icon {
- display: block;
- }
- }
- .stats-row:hover {
- background: rgba(0, 8, 14, 0.03);
- }
- .stats-row .stat-bars {
- flex: 1;
- margin: 10px 0 13px;
- padding: 2px 5px;
- width: 100%;
- background: linear-gradient(
- to top,
- var(--background-modifier-accent),
- var(--background-modifier-accent) 1px,
- transparent 1px
- );
- background-position: center bottom;
- background-size: 100% 12px;
- display: flex;
- align-items: flex-end;
- justify-content: center;
- }
- .stat-bars .stat-bar {
- border-radius: 5px;
- max-width: 10px;
- flex: 1;
- color: #a9bcc4;
- background: #a9bcc4;
- &--outbound {
- opacity: 0.38;
- color: #a9bcc4;
- background: #a9bcc4;
- }
- }
- .stat-legend {
- margin-top: 30px;
- @include bidi-style(margin-left, auto, margin-right, 0);
- display: flex;
- }
- .stat-legendEntry {
- font-size: 11px;
- line-height: 1;
- @include bidi-style(margin-left, 20px, margin-right, 0);
- background: none !important;
- }
- .stat-circle {
- margin-bottom: -1px;
- @include bidi-style(margin-right, 3px, margin-left, 0);
- width: 10px;
- height: 10px;
- border-radius: 100%;
- display: inline-block;
- }
- .ticket_channel_distribution {
- .stat-graphic {
- align-items: stretch;
- }
- .stats-row {
- margin-bottom: -4px;
- position: relative;
- }
- }
- .frequency.stat-widget {
- .stat-bars {
- margin-top: 0;
- }
- .stats-row {
- margin-bottom: 0;
- }
- .stat-label {
- color: var(--text-muted);
- }
- .primary {
- color: hsl(145, 51%, 45%);
- background: hsl(145, 51%, 45%);
- }
- }
- .activity.sidebar {
- width: 370px;
- padding: 0;
- border-left: 1px solid var(--border);
- }
- .activity h2 {
- margin-left: 19px;
- margin-bottom: 15px;
- margin-right: 26px;
- @include rtl(margin-right, 19px);
- @include rtl(margin-left, 26px);
- }
- .activity-entries {
- margin: 0 -17px;
- }
- .activity-placeholder {
- @extend .u-textTruncate;
- padding: 0 17px;
- }
- .activity-entry {
- display: flex;
- padding: 0 17px;
- &.is-inactive {
- opacity: 0.5;
- }
- &.is-hover {
- background-color: var(--background-primary);
- }
- &.activity-entry--removeable {
- @include bidi-style(padding-right, 0, margin-left, 17px);
- }
- &:not(:hover) .activity-remove {
- opacity: 0;
- }
- &:not(:last-child) .activity-body::after {
- content: '';
- position: absolute;
- bottom: 0;
- right: 0;
- left: 0;
- border-bottom: 1px solid var(--background-modifier-accent);
- }
- &.activity-entry--removeable:not(:last-child) .activity-body::after {
- right: 17px;
- @include bidi-style(right, 17px, left, 0);
- }
- }
- .activity-avatar {
- padding: 16px 2px 0;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- flex-shrink: 0;
- }
- .activity-body {
- padding: 16px 0 16px 2px;
- @include rtl(padding, 16px 2px 16px 0);
- position: relative;
- display: flex;
- flex: 1;
- min-width: 0; /* Firefox wrong content-calculation with word-wrap workaround */
- color: inherit;
- }
- .activity-message {
- color: inherit;
- flex: 1;
- min-width: 0; /* Firefox wrong content-calculation with word-wrap workaround */
- &:hover .activity-text {
- text-decoration: underline;
- }
- }
- .activity-time {
- margin-top: 2px;
- color: var(--text-muted);
- display: block;
- }
- .activity-remove {
- display: flex;
- align-items: center;
- justify-content: center;
- @extend %clickable;
- padding-left: 10px;
- padding-right: 27px;
- @include rtl(padding-left, 27px);
- @include rtl(padding-right, 10px);
- .activity-remove-icon-holder {
- width: 19px;
- height: 19px;
- border-radius: 100%;
- display: flex;
- align-items: center;
- justify-content: center;
- background: var(--ghost-color);
- }
- .icon {
- fill: var(--text-inverted);
- width: 9px;
- height: 9px;
- }
- &:hover {
- .activity-remove-icon-holder {
- background: #972e29;
- }
- .icon {
- opacity: 1;
- }
- }
- }
- .form-inline {
- display: flex;
- @include phone {
- flex-wrap: wrap;
- .alert {
- flex-basis: 100%;
- }
- }
- }
- .form-inline .input-group-addon,
- .form-inline .form-control:not(textarea) {
- background: var(--background-secondary);
- border: none;
- line-height: 1;
- }
- .form-inline .form-group {
- overflow: hidden;
- position: relative;
- height: 60px;
- flex: 1 1 auto;
- @include phone {
- width: 50%;
- margin-bottom: 0;
- }
- &.datetime {
- min-width: 140px;
- overflow: visible; // datepicker popup needs to be visible
- }
- }
- .form-group.is-changed {
- position: relative;
- }
- .form-group.is-changed::before {
- content: '';
- position: absolute;
- top: 23px;
- left: -12px;
- bottom: 0;
- width: 3px;
- background: repeating-linear-gradient(
- 45deg,
- var(--background-modifier-border),
- var(--background-modifier-border) 5px,
- transparent 5px,
- transparent 9px
- )
- repeat center;
- background-size: 11px 11px;
- }
- .form-inline .form-group.is-changed::before {
- width: 100%;
- height: 3px;
- top: 0;
- left: 0;
- bottom: auto;
- }
- .form-group.is-changed label {
- color: var(--text-muted);
- position: relative;
- }
- .form-group.is-changed label::before {
- position: absolute;
- content: '';
- left: -10px;
- width: 5px;
- height: 5px;
- top: 50%;
- margin-top: -3px;
- border-radius: 100%;
- background: var(--interactive-muted-alt);
- }
- .form-inline .form-group .btn {
- margin: 10px;
- }
- .form-inline .form-group:not(:last-child),
- .form-inline.form-inline--enclosed .form-group {
- border-right: 1px solid var(--border);
- }
- .form-inline .form-group,
- .form-inline.form-inline--enclosed .form-group {
- @include phone {
- border-bottom: 1px solid var(--border);
- &:nth-child(even) {
- border-right-width: 0;
- }
- }
- }
- .form-inline .input-group-addon {
- width: auto;
- padding: 0;
- margin: 10px 18px 0;
- font-size: 13px;
- letter-spacing: 0.05em;
- display: inline-block;
- position: relative;
- }
- .form-inline .form-control:not(textarea) {
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
- position: absolute;
- padding: 28px 5px 12px 20px;
- float: none;
- display: block;
- border-radius: 0;
- }
- .form-inline {
- .formGroup-label {
- z-index: 1;
- pointer-events: none;
- }
- .controls--datetime,
- .controls--date,
- .controls--select {
- position: static;
- }
- .controls--datetime {
- position: absolute;
- bottom: 12px;
- left: 0;
- padding: 0 5px 0 20px;
- width: 100%;
- .controls-label {
- display: none;
- }
- .form-control {
- width: 70px;
- line-height: inherit;
- position: static;
- padding: 0;
- height: auto;
- &.time {
- margin-left: 5px;
- width: 38px;
- }
- }
- }
- }
- .bulkAction-secondStep .form-group {
- min-width: 140px;
- @include phone {
- min-width: 0;
- &.textarea {
- border-bottom-width: 0;
- }
- }
- }
- .bulkAction-secondStep .form-inline .textarea.form-group {
- padding: 5px 10px;
- height: auto;
- }
- .bulkAction-secondStep .form-inline .textarea.form-group .input-group-addon {
- margin-left: 8px;
- margin-right: 8px;
- margin-bottom: 5px;
- }
- .bulkAction-secondStep .form-inline textarea.form-control {
- display: block;
- width: 100%;
- resize: vertical;
- }
- .bulkAction-secondStep .form-inline .textarea .controls {
- margin: 0 6px;
- }
- .bulkAction-secondStep .form-inline textarea.form-control:not(:focus) {
- border-color: #f0f0f0;
- }
- .ticketZoom {
- background: var(--background-primary);
- }
- .ticketZoom-controls {
- display: flex;
- justify-content: flex-end;
- align-items: center;
- padding: 28px 0 0;
- @include bidi-style(margin-right, -40px, margin-left, 0);
- @include phone {
- padding: 10px;
- @include bidi-style(margin-right, 0, margin-left, 0);
- }
- }
- .icon-marker {
- fill: hsl(0, 0%, 61%);
- width: 17px;
- height: 19px;
- }
- .ticketNumberCopy-icon {
- vertical-align: top;
- fill: currentColor;
- }
- .ticketZoom .ticketZoom-header {
- margin-top: 6px;
- padding: 0;
- @include phone {
- margin-top: 10px;
- }
- }
- .ticketZoom .ticket-article {
- margin-top: 55px;
- @include phone {
- margin-top: 40px;
- }
- }
- .ticketZoom > .overview-navigator {
- margin-top: 32px;
- @include bidi-style(padding-left, 20px, padding-right, 0);
- }
- .scrollPageAlert {
- @extend .zIndex-5;
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- transform: translateY(0);
- border-bottom: 1px solid var(--border);
- & > .alert {
- margin-bottom: 0;
- border-radius: 0;
- text-align: center;
- }
- }
- .ticket-article,
- .article-new {
- max-width: 1080px;
- margin: 0 auto;
- padding: 0 21px;
- @include phone {
- padding: 0 10px;
- }
- }
- .ticket-title {
- max-width: 1080px;
- padding: 0 81px;
- @include phone {
- padding: 0 10px;
- }
- }
- .ticket-title-update {
- @extend h1;
- white-space: normal;
- margin-top: 15px;
- margin-bottom: 8px;
- padding: 0 7px;
- text-align: center;
- .ticketZoom-header & {
- &:hover,
- &:focus {
- background: var(--background-modifier-hover);
- }
- }
- }
- .task-subline {
- text-align: center;
- display: block;
- }
- .ticket-article-item {
- padding-bottom: 33px;
- position: relative;
- z-index: 1; // fixed chrome 49 + flex issue, not shown article
- .avatar {
- position: absolute;
- right: 0;
- top: 5px;
- @include phone {
- position: static;
- margin: 0 5px 7px;
- }
- }
- &.agent .avatar {
- right: auto;
- left: 0;
- }
- }
- /*
- clip the article-meta to not stand out on the other side
- of the textBubble if the text bubble is small
- */
- .article-meta-clip {
- overflow: hidden;
- position: relative;
- height: 100%;
- margin: 0 55px;
- @include phone {
- margin: 0;
- }
- }
- .article-content {
- color: var(--text-normal);
- position: relative;
- z-index: 1;
- padding: 0 55px;
- @include phone {
- padding: 0;
- }
- &.article-actions {
- justify-content: space-around;
- }
- }
- .article-content-meta {
- position: absolute;
- width: 100%;
- }
- .article-meta {
- background: var(--background-tertiary);
- color: var(--text-inverted);
- padding: 21px 25px 11px;
- margin: 0 12px;
- @include phone {
- margin: 0 5px;
- padding: 10px 10px 5px;
- }
- }
- .article-meta.bottom {
- padding-top: 17px;
- padding-bottom: 8px;
- @include phone {
- padding-top: 10px;
- padding-bottom: 5px;
- }
- }
- .article-meta-row {
- margin-bottom: 5px;
- }
- .article-meta-key {
- width: 20%;
- text-transform: uppercase;
- flex-shrink: 0;
- @include phone {
- width: 50px;
- }
- }
- .article-meta-value {
- @include bidi-style(margin-left, 8px, margin-right, 0);
- overflow: hidden;
- text-overflow: ellipsis;
- span {
- white-space: nowrap;
- }
- }
- .article-meta-icon {
- fill: var(--text-inverted);
- vertical-align: top;
- margin: 2px 3px 0 0;
- @include rtl(margin, 2px 0 0 3px);
- &.icon-lock,
- &.icon-encryption-error {
- margin: 0;
- }
- }
- .article-meta-permanent {
- margin: 0 55px;
- + .article-content .textBubble {
- border-top-left-radius: 0;
- border-top-right-radius: 0;
- border-top-width: 0;
- }
- .alert {
- margin-bottom: 0;
- padding-left: 20px;
- padding-right: 20px;
- border-radius: 0;
- box-shadow: 0 0 0 1px inset hsla(0, 0%, 0%, 0.04);
- &:first-child {
- border-top-left-radius: 2px;
- border-top-right-radius: 2px;
- }
- &--blank {
- background: var(--background-article-meta);
- color: var(--text-muted-alt);
- border: 1px solid var(--border-alt);
- .customer.ticket-article-item & {
- background: var(--background-article-customer-meta);
- border-color: var(--border-article-customer);
- }
- .customer.state--folde-out & {
- border-color: var(--border-article-customer-selected);
- }
- }
- .icon {
- fill: currentColor;
- margin: 2px 6px 0 0;
- vertical-align: top;
- width: 14px;
- height: 14px;
- }
- .icon-lock {
- margin-top: 1px;
- width: 16px;
- height: 16px;
- }
- }
- }
- .internal-border {
- padding: 5px;
- border-radius: 5px;
- margin: -5px;
- }
- .is-internal .internal-border {
- background: repeating-linear-gradient(
- 45deg,
- var(--border-internal),
- var(--border-internal) 5px,
- var(--border-internal-stripe) 5px,
- var(--border-internal-stripe) 10px
- );
- background-size: 14px 14px;
- background-position: -1px;
- }
- .is-internal .bubble-arrow {
- display: none;
- }
- .article-visibility-text-wrapper {
- padding: 0 55px;
- opacity: 0;
- height: 0;
- .article-visibility-text {
- margin-bottom: 17px;
- &.is-hidden {
- display: none;
- }
- }
- }
- .textBubble {
- padding: 10px 20px;
- background: var(--background-secondary);
- border-radius: 2px;
- border: 1px solid var(--border-alt);
- box-shadow: 0 0 1px rgba(0, 0, 0, 0.06) inset;
- position: relative;
- @include phone {
- padding: 10px;
- }
- /* email css reset */
- p {
- margin: 0;
- }
- .is-internal & {
- border-color: var(--border-internal) !important;
- }
- }
- .textBubble-content {
- overflow: hidden;
- position: relative;
- }
- .textBubble-footer {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin: 0 -12px -28px;
- padding: 6px 12px;
- border-radius: 0 0 4px 4px;
- }
- .textBubble-footer:has(+ .attachments .attachment) {
- margin-bottom: -10px;
- }
- .textBubble-footer:not(.is-open .textBubble-footer) {
- visibility: hidden;
- }
- .textBubble-control {
- display: flex;
- }
- .textBubble-letterCount:not(.label-danger, .label-warning) {
- color: var(--ghost-color);
- }
- .textBubble-overflowContainer {
- position: absolute;
- bottom: 0;
- left: 0;
- right: 0;
- background: var(--background-secondary);
- &.is-open {
- &::before {
- display: none;
- }
- }
- .btn {
- padding-top: 15px;
- padding-bottom: 15px;
- font-size: 10px;
- }
- &::before {
- content: '';
- position: absolute;
- left: 0;
- right: 0;
- top: -30px;
- height: 30px;
- background: linear-gradient(
- rgba(255, 255, 255, 0),
- var(--background-secondary)
- );
- pointer-events: none;
- }
- }
- .customer .textBubble-overflowContainer {
- background: var(--background-article-customer);
- &::before {
- background: linear-gradient(
- hsla(199, 44%, 93%, 0),
- var(--background-article-customer)
- );
- }
- }
- .customer.ticket-article-item .textBubble {
- background: var(--background-article-customer);
- border-color: var(--border-article-customer);
- box-shadow: none;
- }
- .customer .richtext-content blockquote {
- border-left: 5px solid var(--background-modifier-border);
- }
- .customer.ticket-article-item.state--folde-out .textBubble {
- border-color: var(--border-article-customer-selected);
- }
- .bubble-arrow {
- position: absolute;
- width: 6px;
- height: 9px;
- left: -6px;
- top: 15px;
- overflow: hidden;
- @include phone {
- left: 14px !important;
- top: -5px;
- width: 9px;
- height: 6px;
- }
- }
- .bubble-arrow::after {
- content: '';
- position: absolute;
- top: -1px;
- left: 1px;
- width: 11px;
- height: 11px;
- background: var(--background-secondary);
- border: 1px solid var(--border-alt);
- box-shadow: 0 0 1px rgba(0, 0, 0, 0.06) inset;
- transform: rotate(-45deg);
- @include phone {
- top: 2px;
- left: -1px;
- }
- }
- .customer.ticket-article-item .bubble-arrow {
- left: auto;
- right: -6px;
- @include phone {
- left: 14px;
- right: auto;
- top: -4px;
- }
- }
- .customer.ticket-article-item .bubble-arrow::after {
- background: var(--background-article-customer);
- left: auto;
- right: 2px;
- border-color: var(--border-article-customer);
- box-shadow: none;
- @include phone {
- left: -1px;
- right: auto;
- }
- }
- .customer.ticket-article-item.state--folde-out .bubble-arrow::after {
- border-color: var(--border-article-customer-selected);
- }
- .remote-content-message {
- border-top: 1px solid var(--background-modifier-border);
- white-space: normal;
- margin: 10px -20px -10px;
- padding: 10px 20px 10px 40px;
- text-indent: -20px;
- position: relative;
- font-size: 13px;
- cursor: pointer;
- &:hover {
- background-color: var(--background-modifier-hover);
- }
- .icon-danger {
- vertical-align: text-bottom;
- color: var(--text-normal);
- }
- @include phone {
- margin-left: -10px;
- margin-right: -10px;
- padding: 10px 15px 10px 30px;
- }
- }
- .attachments.attachments--list:not(:empty) {
- border-top: 1px solid var(--background-modifier-border);
- white-space: normal;
- margin: 10px -20px 0;
- padding: 26px 20px 7px 72px;
- position: relative;
- @include phone {
- margin-left: -10px;
- margin-right: -10px;
- padding: 20px 15px 7px 30px;
- }
- &.attachments--wo-body {
- border-top: none;
- margin-top: 0;
- padding-top: 12px;
- }
- }
- .attachments.attachments--list .attachments-title {
- font-size: 13px;
- font-weight: 500;
- text-transform: uppercase;
- padding: 0 7px;
- .badge {
- margin: -1px 0 0 5px;
- }
- }
- .attachments > .icon:first-child {
- position: absolute;
- left: 33px;
- top: 27px;
- fill: var(--ghost-color);
- @include phone {
- width: 16px;
- height: 16px;
- left: 12px;
- top: 20px;
- }
- }
- .attachments-block {
- margin-bottom: 12px;
- &:last-child {
- margin-bottom: 0;
- }
- &-headline {
- font-size: 13px;
- color: var(--text-normal);
- font-weight: 500;
- text-transform: uppercase;
- margin: 0 7px;
- }
- }
- .ticket-article-item .task-subline {
- margin-top: 7px;
- }
- .article-action {
- padding: 5px 16px;
- margin-top: 5px;
- color: var(--interactive-muted);
- font-size: 12px;
- text-align: center;
- @extend .u-clickable;
- }
- .article-action:hover {
- color: var(--text-primary);
- text-decoration: none;
- }
- .article-action-icon {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- vertical-align: top;
- width: 17px;
- height: 17px;
- fill: currentColor;
- }
- .article-action-name {
- @media screen and (max-width: 1080px) {
- display: none;
- }
- @media screen and (max-width: 1358px) {
- .main:not(.is-closed) & {
- display: none;
- }
- }
- }
- .article-add {
- position: relative;
- z-index: 1; // fixed chrome 49 + flex issue, not shown article
- }
- .article-new {
- margin-top: auto;
- margin-bottom: 36px;
- }
- .dropArea {
- background: var(--background-secondary);
- border: 5px solid;
- color: hsl(202, 66%, 55%);
- font-size: 20px;
- margin: 5px;
- display: none;
- @extend .fit;
- &--small {
- margin: 0;
- font-size: inherit;
- border-width: 3px;
- min-height: 38px;
- }
- }
- .is-dropTarget .dropArea {
- display: block;
- }
- .dropContainer {
- position: relative;
- }
- .dropArea-inner {
- @extend .fit;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .shortcut .dropdown-menu > .is-active > a {
- background: none;
- }
- .shortcut > .dropdown-menu {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- position: absolute;
- max-width: 100%;
- min-width: 0;
- }
- .editControls {
- position: absolute;
- left: 0;
- top: 5px;
- @include phone {
- position: static;
- margin: 0 0 10px;
- display: flex;
- align-items: center;
- }
- }
- .article-add[data-type='email'] .editControls {
- top: 159px;
- }
- .editControls-item {
- position: absolute;
- top: 43px;
- @extend .u-clickable, .zIndex-4;
- @include phone {
- position: relative;
- z-index: initial;
- top: 0 !important;
- transform: none !important;
- opacity: 1 !important;
- }
- &.is-hidden {
- display: none;
- @include phone {
- display: block;
- }
- }
- }
- .editControls-item:nth-child(2) {
- @include phone {
- z-index: 1;
- }
- }
- .editControls-item:nth-child(3) {
- top: 79px;
- }
- .editControls-item:nth-child(4) {
- top: 115px;
- }
- .editControls-item:not(:last-child) {
- border-bottom: 1px solid var(--border);
- @include phone {
- border-bottom: 0;
- border-right: 1px solid var(--border);
- }
- }
- .editControls-iconHolder {
- width: 38px;
- height: 35px;
- display: flex;
- align-items: center;
- justify-content: center;
- @include phone {
- width: 48px;
- height: 32px;
- }
- }
- .editControls-icon {
- @include phone {
- line-height: 0.7;
- }
- }
- .editControls-icon .icon {
- fill: var(--interactive-muted);
- }
- .pop-selector {
- position: absolute;
- top: 0;
- left: 0;
- display: flex;
- align-items: center;
- justify-content: center;
- border-radius: 4px;
- box-shadow: var(--elevation-low);
- @include phone {
- top: -4px;
- left: 7px;
- }
- &.is-hidden {
- display: none;
- }
- }
- .pop-selectable {
- width: 35px;
- height: 35px;
- display: flex;
- align-items: center;
- justify-content: center;
- @extend .u-clickable;
- background: var(--background-tertiary);
- }
- .pop-selectable:hover {
- background: var(--highlight);
- }
- .pop-selectable:first-child {
- @include bidi-style(border-radius, 4px 0 0 4px, border-radius, 0 4px 4px 0);
- }
- .pop-selectable:last-child {
- @include bidi-style(border-radius, 0 4px 4px 0, border-radius, 4px 0 0 4px);
- }
- .pop-selectable:only-child {
- border-radius: 4px;
- }
- .pop-selectable:hover .pop-selectable-icon {
- fill: var(--text-inverted);
- }
- .article-add .icon-internal {
- fill: hsl(18, 87%, 65%);
- }
- .article-add.is-public .icon-internal,
- .article-add.is-internal .icon-public {
- display: none;
- }
- .article-new .textBubble {
- border-radius: 5px;
- padding-left: 12px;
- padding-right: 12px;
- cursor: text;
- }
- .articleNewEdit-body {
- width: 100%;
- position: relative;
- min-height: 20px;
- vertical-align: bottom;
- border: none;
- outline: none;
- resize: none;
- height: auto;
- @include phone {
- font-size: 16px;
- }
- }
- .article-new .bubble-arrow::after {
- box-shadow: none;
- }
- .article-attachment {
- position: absolute;
- bottom: -4px;
- left: 10px;
- right: 10px;
- height: 42px;
- padding: 10px 0;
- color: var(--text-muted);
- overflow: hidden;
- @extend .u-textTruncate;
- }
- .attachments:not(:empty) {
- padding: 9px 5px;
- border-top: 1px solid var(--background-modifier-border);
- margin: 6px -12px 30px;
- }
- .ticket-create .attachments:not(:empty) {
- margin-left: 0;
- margin-right: 0;
- margin-bottom: 56px;
- }
- .ticket-create .attachment--row {
- line-height: 1.45;
- }
- .attachment.attachment--row {
- font-size: 13px;
- padding: 1px 10px 1px 7px;
- @include rtl(padding, 1px 7px 1px 10px);
- cursor: default;
- position: relative;
- display: flex;
- }
- .attachment.attachment--preview {
- display: flex;
- font-size: 13px;
- padding: 9px 4px;
- position: relative;
- min-height: 42px;
- color: inherit;
- align-items: flex-start;
- border-bottom: 1px solid var(--background-modifier-border);
- &:last-child {
- border-bottom: none;
- }
- }
- .attachment-icon {
- margin-top: 2px;
- width: 38px;
- text-align: center;
- flex-shrink: 0;
- .icon {
- vertical-align: bottom;
- }
- img {
- width: 30px;
- height: 30px;
- object-fit: cover;
- }
- }
- .attachment--preview {
- .attachment-text {
- margin: 0 4px;
- }
- }
- .attachment--preview .attachment-name {
- min-width: 0;
- display: block;
- @extend .u-highlight;
- word-break: break-all;
- }
- .attachment--preview .attachment-size {
- white-space: nowrap;
- font-size: 11px;
- color: var(--text-muted);
- }
- .attachment--preview .attachment-delete {
- color: var(--interactive-muted);
- text-decoration: underline;
- display: none;
- white-space: nowrap;
- @include bidi-style(margin-left, auto, margin-right, 0);
- @extend .u-clickable;
- @include phone {
- display: block;
- }
- }
- .attachment:hover .attachment--preview .attachment-delete {
- padding: 0 10px 0 30px;
- float: right;
- display: block;
- position: absolute;
- right: 0;
- background: linear-gradient(
- to right,
- transparent,
- var(--background-secondary-hover) 20px
- );
- }
- .attachment--preview .attachment-delete .icon {
- fill: var(--interactive-muted);
- width: 9px;
- height: 9px;
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- .attachment:hover {
- background: var(--background-secondary-hover);
- }
- .attachment--row .attachment-name {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- min-width: 0;
- @extend .u-highlight;
- }
- .attachment--row .attachment-size {
- white-space: nowrap;
- float: right;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- .attachment--row .attachment-delete {
- color: var(--interactive-muted);
- text-decoration: underline;
- display: none;
- white-space: nowrap;
- @include bidi-style(margin-left, auto, margin-right, 0);
- @extend %clickable;
- }
- .attachment:hover.attachment--row .attachment-delete {
- padding: 0 10px 0 30px;
- float: right;
- display: block;
- position: absolute;
- right: 0;
- background: linear-gradient(
- to right,
- transparent,
- var(--background-secondary-hover) 20px
- );
- }
- .attachment--row .attachment-delete .icon {
- width: 9px;
- height: 9px;
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- .attachmentPlaceholder-inputHolder {
- position: relative;
- display: inline-block;
- overflow: hidden;
- vertical-align: bottom;
- pointer-events: auto;
- @extend .u-highlight;
- &:has(input[type='file'][disabled]) {
- color: var(--text-muted-alt);
- pointer-events: none;
- }
- }
- .attachmentUpload {
- color: var(--text-muted);
- }
- .attachmentUpload-cancel {
- @extend .u-clickable;
- @include bidi-style(margin-left, auto, margin-right, 0);
- text-decoration: underline;
- }
- .attachmentUpload .icon {
- fill: var(--interactive-muted);
- width: 9px;
- height: 9px;
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- .attachmentUpload-progressBar {
- position: absolute;
- height: 4px;
- background: hsl(202, 66%, 55%);
- left: 0;
- bottom: 0;
- }
- .attachmentUpload--standalone {
- position: relative;
- margin-bottom: 7px;
- padding-bottom: 2px;
- box-shadow: 0 -4px var(--border) inset;
- &:last-child {
- margin-bottom: 0;
- }
- .attachmentUpload-cancel {
- padding: 0 2px 0 7px;
- }
- }
- .attachmentUploadContainer {
- .attachmentUpload-progressBar {
- position: inherit;
- }
- }
- .tabsSidebar-tabsSpacer {
- @include bidi-style(padding-right, 62px !important, padding-left, 0);
- /*
- force div to show scrollbars
- because we offset the sidebar tabs when the os shows scrollbars
- */
- overflow-x: hidden;
- overflow-y: scroll;
- @include phone {
- @include bidi-style(padding-right, 0 !important, padding-left, 0);
- }
- }
- .tabsSidebar-sidebarSpacer {
- @include bidi-style(margin-right, $sidebarWidth, margin-left, 0);
- transition: margin-right 500ms;
- @include rtl(transition, margin-left 500ms);
- @include desktop {
- @include bidi-style(margin-right, $desktopSidebarWidth, margin-left, 0);
- }
- }
- .tabsSidebar-sidebarSpacer.is-closed {
- margin-right: 0;
- @include rtl(margin-left, 0);
- }
- .tabsSidebar-holder {
- overflow: hidden;
- position: relative;
- flex: 1;
- display: flex;
- flex-direction: column;
- }
- .tabsSidebar .sidebar {
- width: $sidebarWidth;
- border-left: 1px solid var(--border);
- padding: 0;
- margin-bottom: 1px;
- @include desktop {
- width: $desktopSidebarWidth;
- }
- }
- .tabsSidebar .sidebar > hr {
- margin: 20px;
- }
- .tabsSidebar .sidebar-header {
- display: flex;
- align-content: stretch;
- position: relative;
- margin: 0 20px;
- + hr {
- margin-top: 0;
- }
- }
- .sidebar-header-headline {
- padding: 33px 8px 17px 25px;
- @include rtl(padding, 33px 25px 17px 8px);
- margin: 0 0 0 -20px;
- @include rtl(margin, 0 -20px 0 0);
- line-height: 1;
- @extend .u-clickable, .u-textTruncate;
- }
- .sidebar-header-actions {
- flex: 1;
- @include bidi-style(margin-right, 5px, margin-left, 0);
- display: flex;
- align-items: center;
- .dropdown {
- flex: 1;
- position: static;
- }
- .dropdown-toggle {
- padding-top: 38px;
- padding-bottom: 24px;
- }
- }
- .tabsSidebar-close {
- padding: 27px 35px 12px 0;
- margin: 0 -20px 0 0;
- @extend .u-clickable;
- display: flex;
- align-items: center;
- justify-content: center;
- .icon {
- fill: var(--interactive-primary);
- }
- }
- .tabsSidebar .sidebar-content {
- padding: 0 20px 20px;
- }
- .sidebar.bottom-form-shadow {
- box-shadow:
- 0 -1px rgba(0, 0, 0, 0.005) inset,
- 0 -2px rgba(0, 0, 0, 0.005) inset,
- 0 -3px rgba(0, 0, 0, 0.005) inset,
- 0 -4px rgba(0, 0, 0, 0.005) inset;
- }
- .tabsSidebar {
- position: absolute;
- @include bidi-style(right, 0, left, auto);
- top: 0;
- bottom: 0;
- transition: 500ms;
- z-index: 300;
- &.tabsSidebar--attributeBarSpacer {
- bottom: 60px;
- }
- }
- .tabsSidebar.is-closed {
- transform: translateX($sidebarWidth);
- @include rtl(transform, translateX(-$sidebarWidth));
- @include desktop {
- transform: translateX($desktopSidebarWidth);
- @include rtl(transform, translateX(-$desktopSidebarWidth));
- }
- }
- .tabsSidebar-tabs {
- display: flex;
- flex-direction: column;
- justify-content: center;
- position: absolute;
- @include bidi-style(left, -56px, right, auto);
- top: 0;
- bottom: 0;
- pointer-events: none;
- @include phone {
- @include bidi-style(left, -47px, right, auto);
- }
- }
- .test {
- position: absolute;
- width: 100%;
- }
- .tabsSidebar-tab {
- width: 56px;
- height: 60px;
- background: var(--background-primary-alt);
- position: relative;
- border-top: 1px solid var(--border-alt);
- @extend .u-clickable;
- pointer-events: auto;
- display: flex;
- align-items: center;
- justify-content: center;
- @include phone {
- width: 47px;
- height: 50px;
- }
- }
- .tabsSidebar-tab.is-changed::before {
- position: absolute;
- content: '';
- left: -3px;
- width: 6px;
- height: 6px;
- top: 50%;
- margin-top: -3px;
- border-radius: 100%;
- background: var(--interactive-muted-alt);
- box-shadow: 0 0 0 2px var(--background-primary);
- }
- .tabsSidebar-tab:first-child {
- @include bidi-style(border-top-left-radius, 8px, border-top-right-radius, 0);
- border-top: none;
- }
- .tabsSidebar-tab:last-child {
- @include bidi-style(
- border-bottom-left-radius,
- 8px,
- border-bottom-right-radius,
- 0
- );
- }
- .tabsSidebar-tab .icon {
- width: 24px;
- height: 24px;
- fill: var(--interactive-muted-alt);
- }
- .tabsSidebar-tab.active {
- .tabsSidebar-tab-count {
- background: var(--interactive-muted-alt-selected);
- &::after {
- border-right-color: var(--interactive-muted-alt-selected);
- }
- &.tabsSidebar-tab-count--info {
- background: var(--button-primary-background);
- opacity: 1;
- &::after {
- border-right-color: var(--button-primary-background);
- }
- }
- &.tabsSidebar-tab-count--success {
- background: hsl(145, 51%, 45%);
- opacity: 1;
- &::after {
- border-right-color: hsl(145, 51%, 45%);
- }
- }
- &.tabsSidebar-tab-count--warning {
- background: hsl(45, 98%, 63%);
- opacity: 1;
- &::after {
- border-right-color: hsl(45, 98%, 63%);
- }
- }
- &.tabsSidebar-tab-count--danger {
- background: hsl(11, 85%, 48%);
- opacity: 1;
- &::after {
- border-right-color: hsl(11, 85%, 48%);
- }
- }
- }
- .icon {
- fill: var(--interactive-muted-alt-selected);
- }
- }
- .tabsSidebar-tab-count {
- position: absolute;
- left: 9px;
- top: 5px;
- background: var(--interactive-muted-alt);
- width: 16px;
- height: 13px;
- text-align: center;
- border-radius: 2px;
- font-size: 9px;
- line-height: 14px;
- color: var(--background-primary-alt);
- @include phone {
- left: 4px;
- top: 4px;
- }
- [data-tab='organization'] & {
- left: 7px;
- + .icon {
- margin-left: 3px;
- }
- }
- + .icon {
- margin-top: 6px;
- }
- &::after {
- content: '';
- position: absolute;
- top: 100%;
- right: 20%;
- border-bottom: 3px solid transparent;
- border-right: 5px solid var(--interactive-muted-alt);
- }
- &.tabsSidebar-tab-count--info {
- background: var(--button-primary-background);
- opacity: 0.5;
- &::after {
- border-right-color: var(--button-primary-background);
- }
- }
- &.tabsSidebar-tab-count--success {
- background: hsl(145, 51%, 45%);
- opacity: 0.5;
- &::after {
- border-right-color: hsl(145, 51%, 45%);
- }
- }
- &.tabsSidebar-tab-count--warning {
- background: hsl(45, 98%, 63%);
- opacity: 0.5;
- &::after {
- border-right-color: hsl(45, 98%, 63%);
- }
- }
- &.tabsSidebar-tab-count--danger {
- background: hsl(11, 85%, 48%);
- opacity: 0.5;
- &::after {
- border-right-color: hsl(11, 85%, 48%);
- }
- }
- }
- .alert {
- padding: 10px 15px 8px;
- border-radius: 3px;
- color: var(--text-inverted);
- border: none;
- background: hsla(0, 0%, 0%, 0.3);
- .icon {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- fill: currentColor;
- }
- .btn {
- background: hsla(0, 0%, 0%, 0.2);
- border-color: hsla(0, 0%, 0%, 0.1);
- color: inherit;
- }
- &--info {
- background: var(--button-primary-background);
- }
- &--success {
- &,
- &[contenteditable]:hover,
- &[contenteditable]:focus {
- background: hsl(145, 51%, 45%);
- }
- }
- &--warning {
- color: hsl(45, 98%, 17%);
- background: hsl(45, 98%, 63%);
- .btn {
- background: hsla(0, 0%, 100%, 0.2);
- }
- }
- &--danger {
- background: hsl(11, 85%, 48%);
- }
- &--square {
- border-radius: 0;
- }
- &.horizontal .btn {
- margin-top: -5px;
- margin-bottom: -4px;
- &:last-child {
- margin-right: -5px;
- }
- }
- &-row {
- margin: 3px 0;
- + .btn {
- margin-top: 3px;
- }
- }
- }
- .tags,
- .links,
- .time-units,
- .link_kb_answers {
- margin: 20px 0;
- }
- .tags {
- margin-top: 10px;
- }
- .userNotifications label + .btn {
- margin-top: 1px;
- }
- .list {
- padding: 0;
- margin-bottom: 5px;
- }
- .list-title {
- margin-top: 7px;
- margin-bottom: 4px;
- text-transform: uppercase;
- color: var(--ghost-color);
- display: block;
- font-size: 12px;
- font-weight: normal;
- letter-spacing: 0.05em;
- }
- .list-item {
- display: flex;
- align-items: center;
- border-bottom: 1px solid var(--background-modifier-border);
- }
- .list-item-name {
- flex: 1;
- padding: 4px 1px;
- }
- .list-item-delete {
- padding: 0 10px;
- @include bidi-style(margin-right, -3px, margin-left, 0);
- display: flex;
- align-items: center;
- justify-content: center;
- align-self: stretch;
- @extend .u-clickable;
- .icon {
- width: 9px;
- height: 9px;
- fill: var(--interactive-muted);
- }
- }
- .list-item-delete:hover .icon {
- fill: hsl(1, 77%, 47%);
- }
- li.list-item-none {
- list-style-type: none;
- }
- .ticket-id {
- color: var(--text-inverted);
- background: var(--interactive-muted-alt);
- font-size: 11px;
- border-radius: 7px;
- padding: 0 5px;
- @include bidi-style(margin-right, 2px, margin-left, 0);
- }
- .attributeBar {
- background: var(--background-secondary);
- transition: margin 250ms;
- flex-shrink: 0;
- border-top: 1px solid var(--border);
- &.is-closed {
- margin-bottom: -60px;
- }
- @include phone {
- &-reset {
- flex-shrink: 5;
- }
- .btn,
- .buttonDropdown {
- min-width: 20px;
- &--only-icon {
- min-width: 36px;
- }
- }
- }
- &-inner {
- height: 60px;
- display: flex;
- align-items: center;
- justify-content: flex-end;
- padding: 10px;
- }
- &-avatars {
- margin-right: 10px;
- }
- &-draft-spacer {
- width: 1px;
- height: 60px;
- margin-right: 15px;
- background: var(--background-modifier-accent);
- }
- &-avatars:empty + &-draft-spacer {
- display: none;
- }
- &--border {
- border-top: 1px solid var(--border);
- }
- &--spacer-after {
- margin-right: auto;
- }
- }
- .newTicket {
- padding: 14px 34px;
- @include phone {
- padding: 0;
- }
- }
- .newTicket .sidebar {
- width: 290px;
- }
- .newTicket .form-control {
- border-color: var(--border);
- &:focus,
- &.focus {
- border-color: var(--border-highlight);
- }
- }
- .newTicket .article-form-top {
- margin-top: 15px;
- }
- .newTicket--chatTicket {
- flex: 1;
- display: flex;
- padding: 0;
- height: 100%;
- & > .icon {
- position: absolute;
- top: 50%;
- transform: translateY(-50%) translateX(-50%);
- }
- & > .box {
- width: calc(50% - 47px);
- margin: 34px;
- }
- .chatHistory {
- display: flex;
- flex-direction: column;
- }
- .boxFade {
- width: 94px;
- top: 34px;
- height: 100%;
- position: absolute;
- @include bidi-style(margin-left, -34px, margin-right, 0);
- z-index: 1;
- }
- }
- .box {
- background: var(--background-secondary);
- margin: 20px 0;
- border: 1px solid var(--border);
- padding: 20px 24px;
- }
- .box.box--newTicket {
- max-width: 1080px;
- margin-left: auto;
- margin-right: auto;
- @include phone {
- margin: 0;
- border: none;
- padding: 15px;
- }
- }
- .box .page-header {
- text-align: center;
- margin-bottom: 12px;
- }
- .box--paper {
- background-image: linear-gradient(
- transparent 30px,
- var(--background-modifier-border) 31px
- );
- background-size: 100% 31px;
- line-height: 31px;
- padding-top: 31px;
- padding-bottom: 31px;
- h1,
- h2,
- h3 {
- margin: 0;
- line-height: inherit;
- }
- h3:not(:first-child) {
- margin-top: 31px;
- }
- }
- .box h1 {
- margin-top: 10px;
- margin-bottom: 12px;
- color: var(--text-normal);
- flex: 1;
- }
- .box h2 {
- margin-top: 12px;
- }
- .box .two-columns {
- margin-left: -4px;
- margin-right: -4px;
- }
- .box .two-columns .column {
- margin-left: 4px;
- margin-right: 4px;
- width: calc(50% - 8px);
- @include phone {
- width: auto;
- }
- }
- .box-controls {
- margin-top: 20px;
- display: flex;
- align-items: center;
- }
- .box--yellow {
- background: hsl(47, 100%, 93%);
- border-color: hsl(47, 100%, 75%);
- color: hsl(47, 20%, 67%);
- h1,
- h2 {
- color: hsl(47, 3%, 28%);
- }
- }
- .box-progress {
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .box-progress-title {
- color: hsl(47, 3%, 28%);
- }
- .box-progress-body {
- flex: 1;
- @include bidi-style(margin-left, 24px, margin-right, 0);
- display: flex;
- align-items: center;
- justify-content: center;
- progress {
- width: 100%;
- }
- }
- .horizontal > .box {
- margin-top: 4px;
- margin-bottom: 4px;
- & + .box {
- border-left-width: 0;
- }
- }
- .formset-inset {
- margin: 34px -24px 24px;
- padding: 19px 24px 24px;
- background: var(--background-primary-alt);
- border-top: 1px solid var(--border);
- border-bottom: 1px solid var(--border);
- }
- .type-tabs {
- @include phone {
- overflow: hidden;
- -webkit-overflow-scrolling: none;
- }
- }
- .type-tabs .tab {
- height: 40px;
- line-height: 42px;
- padding: 0 12px;
- list-style: none;
- align-items: flex-start;
- @include phone {
- display: block;
- text-align: center;
- flex-shrink: 1;
- }
- }
- .type-tabs .tab-icon {
- width: 17px;
- height: 17px;
- fill: var(--interactive-muted);
- vertical-align: top;
- @include bidi-style(margin-right, 9px, margin-left, 0);
- margin-top: 11px;
- transform: scale(1.2);
- flex-shrink: 0;
- }
- .type-tabs .tab.active .tab-icon {
- fill: var(--text-inverted);
- }
- .token {
- @include ltr(padding, 0 0 0 10px);
- margin: 0 5px 6px 0;
- height: 26px;
- color: var(--tag-text);
- border-radius: 3px;
- background: var(--tag-background);
- border: none;
- float: none;
- display: inline-flex;
- align-items: center;
- cursor: default;
- max-width: 100%;
- &.active {
- background: var(--highlight);
- color: var(--text-inverted);
- .close,
- .token-close {
- opacity: 1;
- }
- }
- }
- /*
- selector needs to be stronger than .token-input
- in order to override input[type=text]
- */
- .tokenfield .token-input {
- vertical-align: top;
- padding: 0 10px 7px 5px;
- margin: 0;
- min-width: 60px;
- height: 32px;
- display: inline-block;
- border: none;
- background: none;
- box-shadow: none;
- outline: none;
- flex: 1;
- &:focus {
- box-shadow: none;
- }
- &[disabled] {
- background: none;
- }
- }
- .tokenfield .token ~ .token-input {
- padding: 0 5px 7px 0;
- }
- .token-label {
- padding: 0;
- @include rtl(padding, 0 10px 0 0);
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .tokenfield.form-control {
- padding: 7px 7px 0;
- height: auto;
- display: flex;
- flex-wrap: wrap;
- }
- .token .close,
- .token-close {
- margin: 0;
- padding: 0 9px 1px 6px;
- font-family: inherit;
- font-weight: 100;
- font-size: 28px;
- line-height: 1;
- color: inherit;
- text-shadow: none;
- opacity: 0.5;
- outline: none;
- height: auto;
- @extend %clickable;
- }
- .token .close:hover,
- .token-close:hover {
- opacity: 0.5;
- }
- /* allow/show autocomplete in modal dialog */
- .ui-autocomplete.ui-widget-content {
- @extend .zIndex-11;
- position: absolute;
- max-height: 380px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- .ui-menu {
- background: var(--background-tertiary);
- border: none;
- color: var(--text-inverted);
- font-family: inherit;
- font-size: inherit;
- .ui-menu-item {
- padding: 9px 15px;
- list-style-image: none;
- &.is-inactive {
- text-decoration: line-through;
- opacity: 0.73;
- }
- &:not(:first-child) {
- box-shadow: 0 1px rgba(255, 255, 255, 0.13) inset;
- }
- &.ui-state-focus {
- margin: 0;
- border: none;
- background: var(--highlight);
- color: inherit;
- + li {
- box-shadow: none;
- }
- }
- }
- }
- .drox {
- color: var(--text-muted);
- }
- .drox .drox-header {
- padding-bottom: 2px;
- margin-bottom: 16px;
- border-bottom: 1px solid var(--background-modifier-border);
- }
- .drox a.create {
- margin-top: 2px;
- display: inline-block;
- }
- .drox .form-group {
- margin-bottom: 22px;
- }
- .drox .drox-body p:first-child {
- margin-top: 20px;
- }
- .newTicket .templates {
- border-bottom: 1px solid var(--background-modifier-border);
- padding-bottom: 14px;
- }
- .templates-manage fieldset {
- margin: 0;
- }
- .template-attributes {
- margin: 17px 0 19px;
- }
- .template-attribute {
- height: 24px;
- line-height: 25px;
- @include bidi-style(padding-left, 10px, padding-right, 0);
- margin-bottom: 2px;
- font-size: 13px;
- color: var(--text-muted-alt);
- background: var(--background-primary-alt);
- border: 1px solid var(--border);
- border-radius: 3px;
- }
- .template-attribute .key {
- text-transform: uppercase;
- @include bidi-style(margin-right, 3px, margin-left, 0);
- }
- .template-attribute .value {
- @include bidi-style(margin-left, 3px, margin-right, 0);
- }
- .template-attribute .delete {
- padding: 0 7px;
- margin-top: 4px;
- line-height: 19px;
- font-size: 28px;
- font-weight: 300;
- opacity: 0.4;
- }
- .customer-name {
- color: var(--text-normal);
- }
- .customer-email {
- margin-top: 5px;
- margin-bottom: 20px;
- display: block;
- }
- .table.user-list {
- tr:hover .switchView {
- visibility: visible;
- }
- td .list {
- margin-top: -4px;
- }
- .switchView {
- visibility: hidden;
- display: block;
- text-overflow: ellipsis;
- overflow: hidden;
- }
- .btn {
- margin: 3px 5px 0;
- }
- }
- .switchBackToUser {
- display: flex;
- align-items: center;
- background: hsl(200, 87%, 45%);
- color: var(--text-inverted);
- height: 45px;
- padding: 0 17px;
- /* top: -45px !important; */
- border-bottom: 5px solid hsl(205, 90%, 60%);
- }
- .switchBackToUser-icon {
- width: 19px;
- height: 18px;
- }
- .switchBackToUser-text {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- .switchBackToUser-close {
- width: 40px;
- height: 40px;
- @include bidi-style(margin-right, -10px, margin-left, 0);
- display: flex;
- align-items: center;
- justify-content: center;
- svg {
- fill: var(--text-inverted);
- }
- }
- .modal {
- @extend .zIndex-11;
- &-loader {
- text-align: center;
- padding: 70px;
- }
- &-backdrop--local {
- background: var(--background-primary-alt);
- }
- }
- .modal-dialog {
- width: auto;
- max-width: 660px;
- margin-top: 35px;
- margin-bottom: 35px;
- @extend .zIndex-11;
- @include phone {
- max-width: calc(100% - 20px) !important;
- margin: 10px;
- }
- &.wizard {
- margin: 35px auto;
- }
- }
- .modal--veryLarge .modal-dialog {
- max-width: 990px;
- }
- .modal--large .modal-dialog {
- max-width: 740px;
- }
- .modal--small .modal-dialog {
- max-width: 440px;
- }
- .modal--dynamicSize .modal-dialog {
- max-width: 100%;
- width: max-content;
- padding: 0 35px;
- @include phone {
- padding: 0;
- margin: 10px;
- }
- }
- .modal-dialog.wizard {
- max-width: 460px;
- }
- .modal-content {
- border-radius: 0;
- border: 1px solid var(--border);
- box-shadow: none;
- color: var(--text-normal);
- background: var(--background-secondary);
- }
- .modal-header {
- padding: 30px 23px 23px;
- border: none;
- @include phone {
- padding: 14px 15px;
- }
- &--empty {
- padding: 0;
- }
- }
- .modal-header h1 {
- text-align: center;
- @include phone {
- text-align: initial;
- line-height: 1.2;
- }
- }
- .modal-close {
- padding: 23px;
- position: absolute;
- z-index: 1;
- right: 0;
- color: var(--interactive-muted);
- @include rtl(right, auto);
- @include rtl(left, 0);
- top: 0;
- @extend .u-clickable;
- @include phone {
- position: static;
- padding: 21px;
- margin: -14px -15px 0 0;
- float: right;
- }
- &:active {
- color: var(--interactive-muted-active);
- }
- .icon-diagonal-cross {
- fill: currentColor;
- }
- }
- .modal-alerts-container {
- padding: 0 23px;
- }
- .modal-body {
- padding: 0 23px;
- clear: both;
- @include phone {
- padding: 0 15px;
- }
- h2:first-child {
- margin-top: 0;
- }
- p:first-child,
- .alert.hidden:first-child + p {
- margin-top: 0;
- }
- .table > thead > tr > th {
- background: var(--background-primary-alt);
- }
- }
- .modal-footer {
- padding: 23px 23px 20px;
- border: none;
- display: flex;
- @include rtl(text-align, left);
- @include phone {
- padding: 15px;
- }
- .btn--text + .btn--text {
- margin-bottom: -10px;
- }
- }
- .modal-leftFooter,
- .modal-centerFooter,
- .modal-rightFooter {
- display: flex;
- align-items: center; /* because of btn--text btn--subtle being thinner than the rest */
- flex: 1;
- }
- .modal.modal--local {
- display: block;
- padding: 0 40px;
- @extend .zIndex-11;
- @include bidi-style(padding-left, 40px, padding-right, 0);
- @include phone {
- padding: 0 !important;
- }
- .modal-dialog {
- box-shadow: 0 0 40px hsla(210, 17%, 40%, 0.34);
- @include dark {
- box-shadow: 0 0 40px hsla(0, 0%, 0%, 0.34);
- }
- }
- }
- .caret {
- position: absolute;
- top: 50%;
- margin-top: -3px;
- right: 10px;
- }
- .dropdown-backdrop {
- @extend .zIndex-5; // has to be behind dropdown-menu
- }
- .dropdown-menu {
- @extend .zIndex-6; // has to be behind modal windows and beneath notifications (popover)
- margin: 0;
- padding: 0;
- min-width: 100%;
- color: var(--text-inverted);
- text-transform: initial;
- letter-spacing: 0;
- background: var(--background-tertiary);
- border-radius: 0;
- border: none;
- box-shadow: none;
- overflow: hidden;
- @include rtl(text-align, right);
- overscroll-behavior: contain;
- }
- .dropdown-menu .divider {
- background: var(--background-modifier-border);
- }
- .dropdown-menu kbd {
- background: none;
- color: inherit;
- padding: 2px 5px;
- @include bidi-style(margin-left, 7px, margin-right, 0);
- line-height: 1;
- vertical-align: baseline;
- opacity: 0.5;
- }
- .dropdown-toggle {
- display: flex;
- align-items: center;
- @extend .u-clickable;
- }
- .dropdown-icon {
- width: 16px;
- height: 16px;
- }
- .dropdown-menu.dropdown-menu--light {
- background: var(--background-secondary);
- color: var(--text-muted);
- }
- .dropdown-menu.dropdown-menu--light > li {
- color: var(--text-nav);
- &.dropdown-header {
- color: var(--text-muted);
- }
- }
- .dropdown-menu.dropdown-menu--light > li > a:hover {
- background: var(--background-secondary-hover);
- }
- .user-menu li.add .dropdown-menu.dropdown-menu--light li > a:hover {
- color: var(--text-normal);
- }
- .dropdown-menu.dropdown-menu--light li:hover {
- background: none;
- }
- .dropdown-menu.dropdown-menu--light li.is-active {
- color: var(--text-inverted);
- }
- .dropdown ul {
- margin: 0;
- padding: 0;
- }
- .dropdown li,
- .dropup li {
- height: 39px;
- line-height: 39px;
- padding: 0 15px;
- @extend %clickable;
- white-space: nowrap;
- &:focus {
- outline: none;
- }
- &.is-active {
- small {
- color: var(--text-muted-highlight);
- }
- }
- }
- .dropdown.dropdown--actions li.with-category {
- height: 39px;
- padding: 2.5px 15px;
- display: block;
- }
- .dropdown li:not(:first-child) {
- box-shadow: 0 1px rgba(255, 255, 255, 0.13) inset;
- }
- .dropdown li.label {
- box-shadow: none;
- + li {
- box-shadow: none;
- }
- }
- .dropdown li:hover,
- .dropdown li.is-active {
- background: var(--highlight);
- + li {
- box-shadow: none;
- }
- }
- .dropdown-menu > li.danger:hover,
- .dropdown-menu > li.danger.is-active {
- background: var(--danger-color);
- }
- .dropdown-menu > li.create:hover,
- .dropdown-menu > li.create.is-active {
- background: hsl(145, 51%, 45%);
- }
- .dropdown-menu > li[disabled] {
- opacity: 0.33;
- &:hover,
- &.is-active {
- background: none;
- cursor: default;
- }
- }
- .dropdown-menu > li > a {
- color: inherit;
- padding: 0 15px;
- margin: 0 -15px;
- line-height: inherit;
- }
- .dropdown-menu > li > a:hover {
- color: inherit;
- background: none;
- }
- .dropdown-menu > li > a span {
- display: block;
- }
- .dropdown-menu .badge--text {
- @include bidi-style(padding-left, 10px, padding-right, 0);
- }
- .dropdown.dropdown--actions {
- li {
- line-height: initial;
- height: auto;
- padding: 11px 15px;
- display: flex;
- align-items: center;
- word-break: break-all;
- }
- .dropdown-iconSpacer,
- .dropdown-selectedSpacer {
- display: flex;
- align-items: center;
- }
- .dropdown-iconSpacer {
- width: 25px;
- }
- .dropdown-selectedSpacer {
- width: 34px;
- @include bidi-style(margin-left, auto, margin-right, 0);
- justify-content: flex-end;
- opacity: 0;
- .icon {
- fill: var(--text-inverted);
- }
- &.is-selected {
- opacity: 1;
- }
- }
- a {
- @extend .u-clickable;
- display: flex;
- flex: 1;
- padding: 0 18px;
- }
- li.dropdown-highlight-list {
- padding: 0 10px;
- a {
- padding: 11px 18px;
- }
- }
- }
- .dropdown.dropdown--wide {
- li {
- padding-top: 12px;
- padding-bottom: 12px;
- }
- }
- li.dropdown-header {
- line-height: 34px;
- height: 30px;
- color: var(--text-muted);
- box-shadow: none !important;
- pointer-events: none;
- }
- .dropdown-menu--has-submenu {
- overflow: hidden;
- background: none;
- ul {
- background: var(--background-tertiary);
- }
- }
- .dropdown-submenu {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- }
- .dropdown.dropdown--actions .dropdown-controls {
- @extend .u-clickable;
- display: flex;
- .icon {
- fill: var(--text-inverted);
- @include bidi-style(margin-right, 10px, margin-left, 0);
- flex-shrink: 0;
- }
- }
- .dropdown-title {
- flex-shrink: 1;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- .dropdown-detail {
- opacity: 0.5;
- }
- .dropdown {
- .dropdown-menu-full-height {
- li {
- padding: 0;
- }
- a {
- padding: 11px 18px;
- margin: 0;
- }
- }
- }
- .recipientList,
- .recipientList-organizationMembers {
- list-style: none;
- padding: 0;
- }
- .recipientList-entry {
- display: flex;
- align-items: center;
- @extend .u-clickable;
- &.is-inactive {
- .recipientList-name {
- text-decoration: line-through;
- opacity: 0.73;
- }
- }
- }
- .recipientList-entry .recipientList-iconSpacer {
- width: 20px;
- @include bidi-style(margin-left, -5px, margin-right, 0);
- display: flex;
- align-items: center;
- justify-content: center;
- flex-shrink: 0;
- }
- .recipientList-icon {
- width: 16px;
- height: 16px;
- fill: var(--text-inverted);
- opacity: 0.2;
- }
- .recipientList--new,
- .recipientList-entry:hover,
- .recipientList-entry.is-active {
- .recipientList-icon {
- opacity: 1;
- }
- }
- .recipientList-name {
- color: var(--text-inverted);
- @include bidi-style(margin-left, 10px, margin-right, 0);
- flex: 1;
- @extend .u-textTruncate;
- }
- .recipientList-status {
- opacity: 0.5;
- margin: 0 10px;
- flex-shrink: 1;
- &:last-child {
- margin-right: 0;
- }
- }
- .recipientList-arrow {
- fill: var(--text-inverted);
- opacity: 0.39;
- }
- .recipientList-entry:hover .recipientList-arrow {
- opacity: 1;
- }
- .recipientList-detail {
- opacity: 0.5;
- &.is-inactive > span {
- text-decoration: line-through;
- }
- }
- .recipientList-icon.plus {
- @include bidi-style(margin-left, 13px, margin-right, 0);
- }
- .recipientList--new {
- background: hsl(145, 51%, 45%);
- }
- .dropdown .recipientList--new:hover {
- background: hsl(147, 52%, 43%);
- }
- .recipientList-controls {
- @extend .u-clickable;
- padding: 0 10px !important;
- .dropdown &:hover {
- background: var(--supergood-color);
- .icon-arrow-left {
- fill: var(--text-inverted);
- }
- }
- & + li {
- box-shadow: 0 1px rgba(255, 255, 255, 0.13) inset;
- }
- }
- .recipientList-organizationMembers {
- position: absolute;
- top: 0;
- left: 0;
- right: 0;
- }
- .organizationInfo-avatar,
- .userInfo-avatar {
- float: right;
- @include rtl(float, left);
- position: relative;
- }
- .userList {
- list-style: none;
- padding: 0;
- .userList-entry {
- margin: 10px 0;
- display: flex;
- align-items: center;
- &:last-child {
- margin-bottom: 0;
- }
- }
- .userList-name {
- @extend .u-textTruncate;
- @include bidi-style(margin-left, 7px, margin-right, 0);
- }
- }
- .checkbox,
- .radio {
- font-size: 14px;
- padding: 0 6px;
- .form-group & {
- padding: 10px 12px;
- margin: 0;
- list-style: none;
- height: auto;
- display: flex;
- flex-direction: column;
- align-items: flex-start;
- background: var(--background-secondary);
- border: 1px solid var(--border);
- }
- .checkbox-replacement {
- display: inline-block;
- }
- label {
- padding-left: 0;
- min-height: 0;
- }
- > label,
- &-child {
- margin-top: 5px;
- font-family: inherit;
- font-size: 14px;
- color: inherit;
- text-transform: inherit;
- letter-spacing: 0;
- line-height: 1.2;
- &:first-child {
- margin-top: 0;
- }
- &.is-disabled {
- cursor: default;
- touch-action: default;
- span {
- opacity: 0.33;
- }
- }
- &.additional-radio-controls {
- margin-top: 0;
- .controls {
- display: inline-flex;
- margin-left: 5px;
- }
- }
- }
- &-child {
- padding-left: 20px;
- }
- .help-text {
- display: table;
- font-size: 0.92em;
- margin: 2px 0 3px 18px;
- }
- }
- .checkbox.form-group .checkbox--list,
- .radio.form-group .radio--list {
- margin-top: 0;
- margin-bottom: 15px;
- height: auto;
- padding-top: 3px;
- padding-bottom: 3px;
- }
- .checkbox,
- .radio {
- &.form-group .controls label {
- padding: 2px 0;
- font: inherit;
- margin-bottom: 0;
- color: inherit;
- text-transform: inherit;
- letter-spacing: 0;
- line-height: 1.2;
- &:first-child {
- margin-top: 0;
- }
- &.is-disabled {
- cursor: default;
- touch-action: default;
- span {
- opacity: 0.33;
- }
- }
- }
- &-child {
- padding-left: 20px;
- }
- }
- .radio_graphic .selections-container {
- display: grid;
- grid-gap: 10px;
- // fit as many as possible in one line, they must at least be 112px wide
- grid-template-columns: repeat(auto-fill, minmax(112px, 1fr));
- label {
- margin-top: 0;
- position: relative;
- }
- .icon {
- flex-shrink: 0;
- }
- .icon-checked {
- display: none;
- }
- .label-box {
- display: block;
- background: var(--background-secondary);
- border: 1px solid var(--border);
- border-radius: 5px;
- overflow: hidden;
- }
- .label-row {
- display: flex;
- align-items: center;
- padding: 5px 10px;
- }
- .label-text {
- display: block;
- margin-left: 5px;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .radio-illustration {
- display: block;
- width: 100%;
- padding-bottom: 100%;
- position: relative;
- img {
- width: 100%;
- height: 100%;
- position: absolute;
- left: 0;
- top: 0;
- object-fit: cover;
- }
- }
- input {
- &:checked {
- ~ .label-box {
- border-color: var(--border-highlight);
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- .icon-checked {
- display: inline;
- }
- .icon-unchecked {
- display: none;
- }
- }
- }
- }
- }
- .userSearch-label {
- margin-top: 11px;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- .userSearch .tab:not(.active) {
- background: var(--background-secondary);
- }
- .userSearch {
- margin: 0 0 20px;
- }
- .userSearch .tabs {
- margin: 0;
- }
- .nav {
- list-style: none;
- padding: 0;
- margin: 0;
- }
- .nav a {
- padding: 10px 15px;
- display: block;
- }
- .nav-tabs {
- display: flex;
- margin: 10px -20px 20px;
- padding: 0 20px 0 21px; /* margin-left: -1px */
- @include rtl(padding, 0 21px 0 20px);
- position: relative;
- }
- .nav-tabs li {
- margin: 0;
- color: var(--interactive-muted);
- border: 1px solid var(--border);
- margin-left: -1px;
- background: var(--background-secondary);
- position: relative;
- &:first-child {
- border-radius: 7px 0 0 7px;
- @include rtl(border-radius, 0 7px 7px 0);
- }
- &:last-child {
- border-radius: 0 7px 7px 0;
- @include rtl(border-radius, 7px 0 0 7px);
- }
- &:only-child {
- border-radius: 7px;
- }
- &.active {
- color: var(--text-inverted);
- background: var(--button-active);
- }
- a {
- padding: 10px 24px 8px;
- color: inherit;
- color: inherit;
- }
- }
- .tab-content {
- h2:first-child {
- margin-top: 0;
- }
- }
- .or-divider {
- position: relative;
- margin: 16px 0;
- text-align: center;
- &::before {
- content: '';
- position: absolute;
- left: 0;
- width: 100%;
- top: 50%;
- margin-top: -1px;
- height: 1px;
- background: hsla(0, 0%, 0%, 0.1);
- }
- span {
- position: relative;
- background: var(--background-secondary);
- padding: 0 10px;
- .modal-body & {
- background: var(--background-primary);
- }
- }
- }
- .settings-entry {
- margin-bottom: 42px;
- max-width: 700px;
- @include phone {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- &--stretched {
- max-width: none;
- }
- }
- .setting-controls {
- margin-top: 14px;
- display: flex;
- justify-content: flex-end;
- }
- .form-item .form-group {
- margin-bottom: 0;
- }
- .form-item .form-group + .form-group {
- margin-top: 15px;
- }
- .form-item + .btn {
- @include bidi-style(margin-left, 23px, margin-right, 0);
- }
- .scrollPageHeader {
- @extend .zIndex-5;
- display: flex;
- align-items: center;
- background: var(--background-secondary);
- border-bottom: 1px solid var(--border);
- height: 64px;
- top: 0;
- left: 0;
- right: 0;
- padding: 0 22px;
- position: absolute;
- transform: translateY(-100%);
- @include phone {
- height: 50px;
- padding: 0 6px;
- overflow: hidden;
- &.is-closed {
- overflow: visible;
- }
- }
- }
- .scrollPageHeader small {
- color: var(--text-muted-alt);
- @include phone {
- margin-top: 1px;
- @include bidi-style(margin-left, 3px, margin-right, 0);
- }
- }
- .scrollPageHeader .ticket-title {
- max-width: initial;
- padding: 0;
- min-width: 0;
- flex: 1;
- }
- .scrollPageHeader h1 {
- font-size: 19px;
- margin: 0 15px;
- @extend .u-textTruncate;
- @include phone {
- font-size: 17px;
- margin: 0 5px;
- }
- }
- .wizard {
- margin: auto; // makes sure that the wizard is scrollable
- }
- .wizard-logo {
- fill: var(--text-inverted);
- @include bidi-style(margin-left, -25px, margin-right, 0);
- margin-bottom: 5px;
- }
- .wizard-slide {
- @extend .hero-unit;
- display: flex;
- flex-direction: column;
- width: 400px;
- padding-bottom: 18px;
- margin-bottom: 20px;
- &.wizard-slide--large {
- width: 460px;
- }
- &.wizard-slide--very-large {
- width: auto;
- max-width: 990px;
- }
- }
- .wizard h2 {
- text-align: center;
- border-bottom: 1px solid rgba(0, 0, 0, 0.13);
- padding-bottom: 8px;
- margin-bottom: 16px;
- & + p {
- margin-top: 0;
- }
- }
- .wizard-body {
- flex: 1;
- padding-bottom: 15px;
- @include phone {
- width: 100%;
- }
- .form-control {
- min-width: 0;
- }
- }
- .wizard-controls {
- display: flex;
- margin-top: 15px;
- height: 39px;
- }
- .wizard-buttonList {
- margin-top: 15px;
- min-width: 200px;
- }
- p + .wizard-buttonList,
- label + .wizard-buttonList {
- margin-top: 5px;
- }
- .wizard-loadingText {
- text-align: center;
- margin: 0;
- }
- .wizard-loadingText .loading {
- vertical-align: middle;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- .wizard-aside {
- padding-top: 15px;
- text-align: center;
- border-top: 1px solid rgba(0, 0, 0, 0.13);
- }
- .setup.wizard .wizard-body {
- min-height: 140px;
- & > p:first-child {
- margin-top: 0;
- }
- }
- .setup.wizard .logo-preview,
- .branding .logo-preview {
- display: block;
- height: 0;
- max-width: 200px;
- max-height: 100px;
- &[src=''] {
- visibility: hidden;
- }
- + .logo-preview-placeholder {
- height: 100px;
- color: var(--text-muted);
- background: var(--background-modifier-accent);
- margin-bottom: 10px;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- }
- .setup.wizard .logo-preview:not([src='']) {
- margin: 0 auto 15px;
- height: auto;
- + .logo-preview-placeholder {
- display: none;
- }
- }
- .setup.wizard .base-outbound-settings {
- margin-top: 15px;
- }
- .branding .logo-preview:not([src='']) {
- margin: 20px auto 12px;
- height: auto;
- + .logo-preview-placeholder {
- display: none;
- }
- }
- .branding.login {
- padding: 24px 24px 0;
- }
- .import.wizard .wizard-slide {
- min-height: 300px;
- }
- .import-source {
- border-radius: 5px;
- border: 1px solid rgba(0, 0, 0, 0.13);
- height: 50px;
- margin: 5px 0;
- @extend .u-clickable;
- }
- .input-feedback {
- position: absolute;
- @include bidi-style(padding-left, 10px, padding-right, 0);
- right: 1px;
- top: 1px;
- bottom: 1px;
- width: 52px;
- border-radius: 0 5px 5px 0;
- background: linear-gradient(to right, rgba(255, 255, 255, 0), white 33%);
- &--no-background {
- background: none;
- }
- }
- .input-group-addon {
- color: inherit;
- }
- .input-feedback--no-background {
- background: none;
- }
- .input-feedback .icon {
- display: none;
- }
- .input-feedback[data-state='loading'] .loading.icon,
- .input-feedback[data-state='error'] .icon-error,
- .input-feedback[data-state='success'] .icon-checkmark {
- display: block;
- }
- .progressTable {
- width: 100%;
- margin: 0 auto;
- }
- .progressTable td {
- padding: 8px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- width: 33%;
- }
- .progressTable tr:not(:last-child) {
- border-bottom: 1px solid #eee;
- }
- .progressTable td:first-child {
- text-align: end;
- }
- .progressTable progress {
- width: 100%;
- min-width: 60px;
- display: block;
- }
- .progressTable .icon-checkmark {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- opacity: 0;
- }
- .progressTable tr.is-done .icon-checkmark {
- opacity: 1;
- }
- .channelList {
- flex: 1;
- display: flex;
- flex-direction: column;
- background: var(--background-secondary);
- border-radius: 2px;
- margin: 5px 0 20px;
- box-shadow: var(--elevation-low);
- }
- .channelList,
- .channelList-controls,
- .channelList-controlEntry {
- border: 1px solid var(--border);
- }
- .channelList-entry {
- display: flex;
- cursor: default;
- padding: 5px 8px;
- &:not(:last-child) {
- border-bottom: 1px solid var(--border);
- }
- }
- .channelList-label {
- margin: 0 10px;
- flex: 1;
- & > * {
- @extend .u-textTruncate;
- }
- }
- .channelList-status {
- font-size: 12px;
- color: var(--text-muted);
- }
- .channelList-placeholder {
- display: flex;
- align-items: center;
- justify-content: center;
- flex: 1;
- color: var(--text-muted);
- }
- .channelList-controls {
- margin-top: auto;
- display: flex;
- background: var(--background-quaternary-alt);
- border-left: none;
- border-right: none;
- border-bottom: none;
- }
- .channelList-controlEntry {
- display: flex;
- justify-content: center;
- width: 26px;
- height: 26px;
- border-left: none;
- border-top: none;
- border-bottom: none;
- position: relative;
- [data-toggle='dropdown'] {
- position: relative;
- }
- .icon {
- opacity: 0.8;
- }
- }
- .avatar-gallery {
- display: flex;
- flex-wrap: wrap;
- }
- .avatar-holder {
- display: inline-block;
- position: relative;
- margin: 0 32px 32px 0;
- border-radius: 100%;
- box-shadow: 0 0 0 4px var(--background-secondary);
- .avatar {
- @extend .u-clickable;
- &.is-active {
- box-shadow: 0 0 0 4px var(--border-highlight);
- }
- }
- }
- .avatar--new {
- background: hsl(145, 51%, 45%);
- @extend .u-clickable;
- }
- .avatar-holder .avatar-delete {
- position: absolute;
- right: -15px;
- top: -15px;
- width: 40px;
- height: 40px;
- pointer-events: none;
- visibility: hidden;
- background: var(--background-secondary);
- display: flex;
- align-items: center;
- justify-content: center;
- border-radius: 100%;
- box-shadow: 0 1px 5px rgba(0, 0, 0, 0.05);
- @extend .u-clickable;
- svg {
- opacity: 0.5;
- fill: var(--interactive-primary);
- }
- &:hover svg {
- opacity: 1;
- }
- }
- .avatar-holder:hover .avatar-delete {
- visibility: visible;
- pointer-events: auto;
- }
- .camera video {
- position: absolute;
- visibility: hidden;
- pointer-events: none;
- }
- .camera-preview {
- display: block;
- margin: 0 auto;
- }
- .camera-flash {
- @extend .fit;
- background: var(--background-secondary);
- opacity: 0;
- @extend .u-unclickable;
- }
- .camera-flash.is-active {
- animation: flash 500ms ease;
- }
- @keyframes flash {
- 0% {
- opacity: 0;
- }
- 50% {
- opacity: 1;
- }
- 100% {
- opacity: 0;
- }
- }
- .fileUpload {
- position: relative;
- overflow: hidden;
- &.btn input:focus + label {
- text-decoration: none;
- }
- }
- .fileUpload label {
- font-size: inherit;
- color: inherit;
- letter-spacing: inherit;
- text-transform: inherit;
- display: inline;
- margin: 0;
- }
- .fileUpload input {
- position: absolute;
- right: 0;
- top: 0;
- font-size: 118px;
- margin: 0;
- padding: 0;
- @extend %clickable;
- opacity: 0;
- &:focus + label {
- text-decoration: underline;
- }
- }
- .imagePreview {
- margin-top: 45px;
- @include phone {
- margin-top: 0;
- }
- img {
- width: auto !important;
- max-width: 100% !important;
- max-height: calc(100vh - 218px) !important;
- }
- }
- .imageCropper p {
- margin: 0;
- }
- .imageCropper-holder {
- height: 340px;
- margin: 15px 0;
- }
- .imageCropper-image {
- max-width: 100%;
- max-height: 100%;
- opacity: 0;
- }
- .imageCropper-preview {
- width: 40px;
- height: 40px;
- border-radius: 100%;
- overflow: hidden;
- margin: 0 10px;
- }
- .cropper-container {
- /* prevent cropper.js's centering – we center via flex */
- left: 0 !important;
- }
- .profile {
- padding: 60px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- flex: 1;
- @include phone {
- padding: 0;
- margin: 0;
- }
- h1 {
- margin: 18px 0 0;
- }
- .tabs {
- margin-top: 2px;
- margin-bottom: 25px;
- }
- }
- .profile-window {
- color: var(--text-normal);
- background: var(--background-secondary);
- max-width: 660px;
- margin: 0 auto;
- border: 1px solid var(--border);
- }
- .profile-section {
- padding: 20px 50px;
- @include phone {
- padding: 10px;
- }
- &.profile-memberSection {
- margin-bottom: 10px;
- }
- }
- .profile-section:not(:last-child) {
- border-bottom: 1px solid var(--background-modifier-border);
- }
- .profile-action {
- @include bidi-style(margin-right, -20px, margin-left, 0);
- @include phone {
- @include bidi-style(margin-right, 0, margin-left, 0);
- }
- .dropdown-toggle {
- margin-top: -20px;
- @include bidi-style(margin-right, -30px, margin-left, 0);
- margin-bottom: 8px;
- padding: 26px 40px 2px;
- @include phone {
- margin-top: -5px;
- padding: 10px 0 5px;
- @include bidi-style(margin-right, 0, margin-left, 0);
- }
- }
- label {
- margin: 0 8px;
- padding: 0;
- cursor: inherit;
- }
- }
- .profile-subtitle {
- font-size: 16px;
- @extend .u-highlight;
- }
- .profile-details {
- @include bidi-style(margin-left, -50px, margin-right, 0);
- }
- .profile-ticketsPlaceholder {
- flex: 1;
- margin: 8px 0 22px;
- color: var(--text-muted);
- .stat-icon {
- margin-bottom: 10px;
- }
- }
- .profile-detailsEntry {
- margin: 8px 0;
- @include bidi-style(padding-left, 50px, padding-right, 0);
- width: 50%;
- }
- .profile-detailsEntry label {
- padding: 0;
- margin-bottom: 2px;
- display: block;
- }
- .profile-organizationMember {
- @extend .profile-detailsEntry;
- display: flex;
- align-items: center;
- .avatar {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- }
- .profile-ticketLists {
- display: flex;
- margin: 0 -25px;
- @include phone {
- display: block;
- margin: 0;
- }
- }
- .profile-ticketList {
- display: flex;
- flex-direction: column;
- flex: 1 1 50%;
- padding: 0 25px;
- min-width: 0; /* Firefox wrong content-calculation with word-wrap workaround */
- @include phone {
- padding: 0;
- margin-bottom: 10px;
- &:last-child {
- margin-bottom: 0;
- }
- }
- .tasks {
- margin-bottom: 10px;
- display: flex;
- flex-basis: auto;
- flex-direction: column;
- }
- }
- .profile .frequency.stat-widget {
- height: 230px;
- @include phone {
- display: none;
- }
- .stat-bars {
- height: 100px;
- }
- }
- .highlighter {
- display: flex;
- }
- [data-highlightcolor='Yellow']::selection {
- background: var(--highlighter-yellow);
- }
- .highlight-Yellow {
- background: var(--highlighter-yellow);
- }
- [data-highlightcolor='Green']::selection {
- background: var(--highlighter-green);
- }
- .highlight-Green {
- background: var(--highlighter-green);
- }
- [data-highlightcolor='Blue']::selection {
- background: var(--highlighter-blue);
- }
- .highlight-Blue {
- background: var(--highlighter-blue);
- }
- [data-highlightcolor='Pink']::selection {
- background: var(--highlighter-pink);
- }
- .highlight-Pink {
- background: var(--highlighter-pink);
- }
- [data-highlightcolor='Purple']::selection {
- background: var(--highlighter-purple);
- }
- .highlight-Purple {
- background: var(--highlighter-purple);
- }
- .translationOverview {
- tbody > tr > td {
- padding: 20px 0 0 10px;
- }
- .translationOverview-itemContainer {
- padding: 10px 0 10px 10px;
- }
- .translationOverview-source {
- width: 25%;
- }
- .translationOverview-target {
- width: 35%;
- }
- .translationOverview-initial {
- width: 25%;
- }
- .translationOverview-item {
- width: 100%;
- }
- }
- .overview-navigator {
- display: flex;
- }
- .overview-navigator .pagination {
- margin: 0 0 0 10px;
- @include rtl(margin, 0 10px 0 0);
- }
- .empty-space {
- padding: 50px;
- svg {
- width: 200px;
- height: auto;
- }
- .empty-space-tagline {
- color: var(--text-muted);
- margin-top: 15px;
- font-size: 18px;
- }
- }
- .horizontal-filters-alert {
- margin-bottom: 10px;
- }
- .horizontal-filters {
- margin-bottom: 20px;
- &--with-switch {
- margin-bottom: 10px;
- }
- .alert {
- margin-top: 10px;
- margin-bottom: 10px;
- }
- .alert + .horizontal-filter {
- border-radius: 4px 4px 0 0;
- }
- .alert + .horizontal-filter:last-child {
- border-radius: 4px;
- }
- }
- .horizontal-filter {
- position: relative;
- display: flex;
- background: var(--background-primary-alt);
- padding: 7px;
- border: 1px solid var(--border-alt);
- &:first-child {
- border-radius: 4px 4px 0 0;
- }
- &:last-child {
- border-radius: 0 0 4px 4px;
- }
- &:only-child {
- border-radius: 4px;
- }
- & + .horizontal-filter {
- border-top: none;
- }
- &-attribute {
- max-width: 250px;
- .modal--veryLarge & {
- max-width: 400px;
- }
- }
- select,
- input {
- border-color: var(--border-alt);
- }
- input[type='text'] {
- width: 100%;
- }
- input[data-item='time'] {
- width: 4.5ch;
- }
- &[data-level] {
- padding-left: 54px;
- @include rtl(padding-left, 7px);
- @include rtl(padding-right, 54px);
- }
- &[data-level='1'] {
- padding-left: 0;
- @include rtl(padding-left, 7px);
- @include rtl(padding-right, 0);
- }
- &[data-level='2'] {
- padding-left: 27px;
- @include rtl(padding-left, 7px);
- @include rtl(padding-right, 27px);
- }
- &[data-level]::before {
- content: '';
- background-color: var(--border-alt);
- width: 54px;
- position: absolute;
- top: 0;
- left: 0;
- bottom: 0;
- @include rtl(right, 0);
- }
- &[data-level='1']::before {
- width: 0;
- }
- &[data-level='2']::before {
- width: 27px;
- }
- .draggable {
- display: flex;
- align-items: center;
- justify-content: center;
- width: 36px;
- height: 39px;
- vertical-align: middle;
- cursor: move;
- }
- .ui-sortable-helper & {
- border-color: transparent;
- border-radius: none;
- background: var(--background-modifier-lighter);
- &[data-level]::before {
- background-color: transparent;
- }
- }
- &.ui-sortable-placeholder {
- visibility: visible !important;
- background: var(--background-primary-alt);
- &[data-level]::before {
- background-color: var(--border-highlight);
- }
- }
- }
- .horizontal-filter-body {
- display: flex;
- flex: 1;
- min-width: 100px;
- @include phone {
- display: block;
- margin-right: 5px;
- }
- > .controls,
- > input {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- @include phone {
- margin: 0 0 5px !important;
- }
- > .controls-label {
- margin-left: 0;
- margin-right: 5px;
- @include rtl(margin-left, 5px);
- @include rtl(margin-right, 0);
- }
- .horizontal-filter-value {
- max-width: 100%;
- }
- }
- > .controls > .controls {
- max-width: 100%;
- + .controls {
- @include bidi-style(margin-left, 5px, margin-right, 0);
- }
- }
- }
- .horizontal-filter-group {
- padding: 10px;
- background: var(--background-secondary);
- border: 1px solid var(--border-alt);
- border-radius: 5px;
- margin: 0 5px;
- > .form-group:last-child {
- margin-bottom: 0;
- }
- }
- .horizontal-filter-value {
- max-width: 60%;
- flex-grow: 1;
- margin-bottom: 0;
- @include phone {
- max-width: 100%;
- }
- // lower the min-width of url input fields (normally 400px) so that it fits in
- input[type='url'] {
- min-width: 200px;
- }
- .dropdown:only-child {
- flex-grow: 1;
- }
- }
- .horizontal-filters-switch {
- display: flex;
- justify-content: flex-end;
- & > label {
- display: flex;
- align-items: center;
- margin-bottom: 0;
- .zammad-switch {
- margin-top: 0;
- margin-left: 10px;
- @include rtl(margin-left, 0);
- @include rtl(margin-right, 10px);
- }
- }
- &--align-start {
- justify-content: flex-start;
- & > label {
- flex-direction: row-reverse;
- .zammad-switch {
- margin-left: 0;
- margin-right: 10px;
- @include rtl(margin-right, 0);
- @include rtl(margin-left, 10px);
- }
- }
- }
- & + .js-preview h3 {
- margin-top: 0;
- }
- }
- .output-input {
- margin: 0 0 14px;
- output {
- margin: 0;
- border-radius: 3px 3px 0 0;
- border: 1px solid var(--border-highlight);
- border-bottom: none;
- display: block;
- }
- input {
- flex: 1;
- border-top-left-radius: 0;
- border-top-right-radius: 0;
- border-top: none;
- &:focus {
- border-color: var(--border);
- box-shadow: none;
- }
- }
- }
- output {
- border-bottom: 1px solid var(--border-highlight);
- margin: 0 0 19px;
- display: inline-block;
- padding: 10px 12px 8px;
- color: inherit;
- background: var(--background-article-customer);
- &[disabled] {
- border-color: hsl(358, 53%, 56%);
- background: hsl(358, 53%, 76%);
- color: var(--text-inverted);
- }
- p {
- margin: 0;
- }
- }
- .zammad-switch {
- overflow: hidden;
- width: 50px;
- height: 30px;
- border-radius: 15px;
- &.zammad-switch--small {
- width: 40px;
- height: 24px;
- border-radius: 12px;
- }
- &.zammad-switch--tiny {
- width: 30px;
- height: 18px;
- border-radius: 9px;
- }
- &.zammad-switch--dark {
- label {
- background: var(--menu-switch-background);
- }
- label::after {
- background: var(--menu-switch-pointer);
- }
- }
- &.zammad-switch--green input:checked + label {
- background: var(--supergood-color);
- }
- }
- .zammad-switch label {
- margin: 0;
- position: relative;
- width: 100%;
- height: 100%;
- border-radius: inherit;
- outline: none;
- background: var(--background-secondary);
- box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.1) inset;
- transition: background 200ms;
- @extend %clickable;
- &::after {
- content: '';
- position: absolute;
- transition: transform 200ms;
- width: calc(60% - 2px);
- height: calc(100% - 2px);
- border-radius: inherit;
- left: 1px;
- top: 1px;
- box-shadow:
- 0 0 0 1px rgba(0, 0, 0, 0.05),
- 0 1px 3px rgba(0, 0, 0, 0.2);
- background: var(--background-secondary);
- @include rtl(transform, translateX(70%));
- }
- }
- .dropdown-menu.dropdown-menu--light .zammad-switch input:not(:checked) + label {
- background: var(--background-primary);
- }
- .zammad-switch input {
- display: none;
- &[disabled] + label {
- cursor: not-allowed;
- opacity: 0.38;
- border-color: var(--border);
- }
- &[disabled] + label::after {
- background: hsl(210, 17%, 97%);
- }
- &:focus + label {
- transition: none;
- background: var(--border-highlight);
- box-shadow: 0 0 0 3px var();
- }
- &:checked + label {
- background: var(--highlight);
- }
- &:checked + label::after {
- transform: translateX(70%);
- @include rtl(transform, none);
- }
- }
- .controls .zammad-switch {
- margin-top: 10px;
- }
- .horizontal-filter-text {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- .filter-controls {
- display: flex;
- margin: 5.5px 0;
- }
- .filter-control {
- display: flex;
- align-items: center;
- justify-content: center;
- width: 30px;
- height: 30px;
- box-shadow: 0 0 0 1px var(--border-alt) inset;
- border-radius: 100%;
- background: var(--background-secondary);
- @extend %clickable;
- &:hover:not(.is-disabled) {
- .icon {
- fill: var(--interactive-primary);
- }
- }
- &.is-disabled {
- cursor: not-allowed;
- opacity: 0.5;
- }
- &:not(:last-child) {
- @include bidi-style(margin-right, 7px, margin-left, 0);
- }
- .icon {
- fill: var(--interactive-muted);
- }
- }
- .filter-preview {
- margin: 20px 0;
- }
- .day-name {
- text-align: center;
- margin-bottom: 0;
- color: inherit;
- white-space: nowrap;
- }
- .form-group.day-time {
- padding: 10px 5px 6px;
- margin: 0;
- label {
- text-align: center;
- }
- .form-control {
- margin-left: auto;
- margin-right: auto;
- margin-bottom: 8px;
- }
- }
- .settings-row {
- margin-bottom: 10px;
- }
- .settings-list {
- border-collapse: separate;
- color: var(--text-normal);
- table-layout: auto;
- margin-bottom: 20px;
- & > caption {
- color: var(--text-normal);
- }
- &.is-invalid {
- border-radius: 3px;
- box-shadow:
- 0 0 0 2px var(--background-primary),
- 0 0 0 4px hsl(0, 90%, 70%);
- }
- &.settings-list--fixed {
- table-layout: fixed;
- }
- &.settings-list--stretch {
- width: 100%;
- }
- &:not(:last-child) {
- margin-bottom: 34px;
- }
- .form-group & {
- margin-bottom: 0;
- }
- &.settings-list--toggleRow {
- tr:not(.is-active) td > *:not(.dont-grey-out) {
- opacity: 0.33;
- }
- }
- &.settings-list--toggleColumn {
- td:not(.is-active) * {
- opacity: 0.33;
- }
- }
- &.settings-list--placeholder {
- th {
- text-align: center;
- border-bottom: 1px solid var(--border-alt);
- border-radius: 4px;
- }
- td {
- height: 40px;
- }
- }
- .settings-list--deleted {
- td {
- text-decoration: line-through;
- }
- }
- th,
- td {
- vertical-align: top;
- padding: 10px;
- border: 1px solid var(--border-alt);
- background: var(--background-secondary);
- }
- th {
- font-weight: normal;
- text-transform: uppercase;
- font-size: 12px;
- line-height: 17px;
- letter-spacing: 0.05em;
- background: var(--background-primary-alt);
- border-bottom: none;
- word-break: normal;
- }
- td {
- word-break: break-word;
- > fieldset {
- margin: 0;
- > .form-group {
- margin-left: 0;
- margin-right: 0;
- }
- > .checkbox,
- > .radio {
- margin: 7px 0;
- }
- }
- }
- td.empty-cell {
- border-top: none;
- }
- .settings-list-separator {
- @include bidi-style(border-left-width, 3px, border-right-width, 1px);
- }
- .text-muted {
- text-transform: none;
- font-size: 10px;
- letter-spacing: 0;
- color: var(--text-muted-alt);
- }
- .inline-label {
- color: inherit;
- }
- th:not(:last-child),
- td:not(:last-child) {
- @include bidi-style(border-right-width, 0, border-left-width, 1px);
- }
- .ui-sortable-placeholder {
- visibility: visible !important;
- td {
- background: none;
- border-left-width: 0;
- border-right-width: 0;
- }
- }
- .ui-sortable-helper td {
- border-bottom-width: 1px !important;
- }
- tr:not(:last-child) td,
- & > tbody:not(:last-child) tr td {
- border-bottom-width: 0;
- }
- tr.is-inactive td {
- color: hsl(199, 19%, 80%);
- text-decoration: line-through;
- }
- & > thead > tr > th:first-child {
- @include bidi-style(
- border-top-left-radius,
- 4px,
- border-top-right-radius,
- 0
- );
- }
- & > thead > tr > th:last-child {
- @include bidi-style(
- border-top-right-radius,
- 4px,
- border-top-left-radius,
- 0
- );
- }
- & > tbody:last-child > tr:last-child > td:first-child,
- & > tfoot:last-child > tr:last-child > td:first-child {
- @include bidi-style(
- border-bottom-left-radius,
- 4px,
- border-bottom-right-radius,
- 0
- );
- }
- & > tbody:last-child > tr:last-child > td:last-child,
- & > tfoot:last-child > tr:last-child > td:last-child {
- @include bidi-style(
- border-bottom-right-radius,
- 4px,
- border-bottom-left-radius,
- 0
- );
- }
- p {
- margin: 0;
- }
- .settings-list-action-cell {
- @extend .u-clickable;
- text-align: center;
- color: var(--interactive-muted);
- background: linear-gradient(
- hsla(0, 0%, 100%, 0.02),
- hsla(0, 0%, 100%, 0.02)
- ),
- linear-gradient(
- var(--background-primary-alt),
- var(--background-primary-alt)
- );
- line-height: 1;
- padding-top: 11px;
- padding-bottom: 9px;
- &:hover {
- color: var(--text-normal);
- }
- .icon {
- fill: currentColor;
- vertical-align: top;
- margin-top: -2px;
- }
- }
- .settings-list-controls {
- padding: 0;
- & > div,
- & > a {
- display: flex;
- min-height: 40px;
- }
- .settings-list-control {
- display: flex;
- align-items: center;
- justify-content: center;
- padding: 0 10px;
- @extend %clickable;
- .icon {
- fill: currentColor;
- }
- }
- }
- .settings-list-control-cell {
- padding: 5px;
- .btn--text {
- margin: -5px;
- }
- & ~ .settings-list-row-control {
- padding-bottom: 7px;
- }
- }
- .settings-list-checkbox-cell,
- .settings-list-radio-cell {
- vertical-align: middle;
- padding-left: 8px;
- }
- .settings-list-radio-cell {
- text-align: center;
- }
- .settings-list-wrapping-cell {
- display: flex;
- align-items: center;
- flex-wrap: wrap;
- }
- .settings-list--bottom-button {
- margin-top: 10px;
- }
- .settings-list-middle {
- vertical-align: middle;
- }
- }
- .settings-list--roles-permissions {
- margin-left: 18px;
- margin-right: 18px;
- margin-top: 10px;
- th:first-child {
- min-width: 150px;
- }
- }
- .select-boxes {
- display: flex;
- align-items: flex-start;
- }
- .select-box {
- display: flex;
- flex-wrap: wrap;
- margin: 0 14px;
- background: var(--background-secondary);
- color: var(--text-normal);
- @include bidi-style(
- border-right,
- 1px solid var(--border-alt),
- border-left,
- none
- );
- border-bottom: 1px solid var(--border-alt);
- border-radius: 3px 3px 0 0;
- &.select-box--vertical .select-value {
- flex-basis: 100%;
- }
- &.select-box--four .select-value {
- flex-basis: 25%;
- }
- &.select-box--six .select-value {
- flex-basis: calc(100% / 6);
- }
- .select-box-header {
- @extend label;
- margin: 0;
- color: inherit;
- display: flex;
- align-items: center;
- padding: 8px 10px;
- flex-basis: 100%;
- white-space: nowrap;
- background: var(--background-primary-alt);
- @include bidi-style(
- border-left,
- 1px solid var(--border-alt),
- border-right,
- none
- );
- border-top: 1px solid var(--border-alt);
- border-radius: 3px 3px 0 0;
- }
- .select-value {
- display: flex;
- align-items: center;
- justify-content: center;
- min-height: 34px;
- background-clip: content-box;
- box-shadow:
- 1px 0 var(--border-alt) inset,
- 0 1px var(--border-alt) inset;
- @extend %clickable;
- &.is-selected {
- background-color: var(--highlight);
- box-shadow: none;
- color: var(--text-inverted);
- }
- }
- &:first-child {
- @include bidi-style(margin-left, 0, margin-left, 14px);
- }
- &:last-child {
- @include bidi-style(margin-right, 0, margin-left, 14px);
- }
- }
- .searchableSelect {
- position: relative;
- .form-control {
- padding-right: 37px;
- @include bidi-style(padding-right, 37px, padding-left, 12px);
- }
- .searchableSelect-main {
- position: relative;
- line-height: 19px;
- &--with-clear-button {
- padding-right: 60px;
- @include bidi-style(padding-right, 60px, padding-left, 12px);
- }
- &.form-control--small ~ .searchableSelect-autocomplete {
- top: 6px;
- left: 9px;
- }
- }
- .searchableSelect-shadow {
- position: absolute;
- @include bidi-style(left, -9999px, right, -9999px);
- }
- .dropdown-menu {
- margin-top: -3px;
- max-width: 100%;
- }
- &-option-text {
- flex: 1 1 0%;
- text-overflow: ellipsis;
- overflow: hidden;
- white-space: nowrap;
- display: block;
- & + .icon {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- &.is-inactive {
- opacity: 0.33;
- cursor: not-allowed;
- }
- }
- &.dropdown li {
- &.has-inactive {
- cursor: unset;
- }
- &.is-selected {
- @include bidi-style(
- border-left,
- 5px solid var(--highlight),
- border-right,
- 5px solid var(--highlight)
- );
- }
- &.js-enter:hover,
- &.js-enter.is-active {
- background: none;
- + li {
- box-shadow: 0 1px rgba(255, 255, 255, 0.13) inset;
- }
- }
- &.js-enter.is-highlighted {
- span.searchableSelect-option-text {
- background: var(--highlight);
- }
- }
- &.js-back:hover,
- &.js-back.is-active {
- background: var(--supergood-color);
- .icon-arrow-left,
- .icon-arrow-right {
- opacity: 1;
- }
- }
- &.is-hidden {
- display: none;
- }
- &.js-enter {
- padding: 0;
- span.searchableSelect-option-text {
- padding: 11px 15px;
- }
- span.searchableSelect-option-arrow {
- padding: 11px 15px;
- cursor: pointer;
- &:hover {
- background: var(--supergood-color);
- .recipientList-arrow {
- opacity: 1;
- }
- }
- }
- }
- span.searchableSelect-option-text {
- letter-spacing: -0.02rem;
- &:hover {
- background: var(--highlight);
- }
- }
- }
- li:not(.is-active):hover + li {
- box-shadow: 0 1px rgba(255, 255, 255, 0.13) inset;
- }
- .searchableSelect-autocomplete {
- position: absolute;
- left: 13px;
- top: 11px;
- right: 37px;
- white-space: nowrap;
- overflow: hidden;
- display: flex;
- pointer-events: none;
- white-space: pre;
- line-height: 19px;
- }
- .searchableSelect-autocomplete-invisible {
- color: transparent;
- }
- .searchableSelect-autocomplete-visible {
- color: hsl(0, 0%, 33%);
- background: hsl(201, 61%, 90%);
- }
- .loading.icon {
- position: absolute;
- right: 11px;
- top: 11px;
- display: none;
- }
- &.is-loading {
- .loading.icon {
- display: block;
- }
- .icon-arrow-down {
- display: none;
- }
- }
- }
- .action {
- background: var(--background-secondary);
- border: 1px solid var(--border);
- box-shadow: var(--elevation-stroke);
- display: flex;
- flex-wrap: wrap;
- padding: 10px;
- margin-bottom: 17px;
- &.is-inactive {
- background: none;
- box-shadow: none;
- position: relative;
- top: 2px;
- border-color: var(--border-alt);
- & > *:not(.action-controls) {
- opacity: 0.33;
- }
- }
- &--placeholder {
- padding: 30px;
- align-items: center;
- justify-content: center;
- color: hsl(206, 9%, 69%);
- box-shadow: none;
- background: none;
- border-style: dashed;
- font-style: italic;
- }
- &-alert {
- width: calc(100% + 20px);
- margin: -10px -10px 10px;
- }
- &-flow {
- display: flex;
- flex-wrap: wrap;
- &.action-flow--noWrap {
- flex-wrap: nowrap;
- }
- &.action-flow--row {
- flex-basis: 100%;
- }
- &.action-flow--vertically-centered {
- align-items: center;
- }
- }
- &-separator {
- width: 1px;
- background: hsl(0, 0%, 97%);
- margin: 0 10px;
- }
- .table {
- margin-left: -9px;
- margin-right: -9px;
- }
- h2 {
- margin-bottom: 0;
- .action-form-status .icon {
- margin-top: 0;
- }
- }
- &-block,
- &-controls,
- &-row {
- padding: 10px;
- h2:first-child,
- h3:first-child {
- margin-top: 0;
- }
- }
- &-block {
- &.action-block--flex {
- flex: 1;
- }
- }
- &-row {
- flex-basis: 100%;
- }
- h3 {
- color: var(--text-muted);
- margin-top: 0;
- + .btn--text {
- position: relative;
- top: -1px;
- }
- }
- &-label {
- background: var(--background-primary-alt);
- border: 1px solid var(--border-alt);
- align-self: flex-start;
- padding: 5px 10px;
- margin: -4px 0 -5px auto;
- @include rtl(margin, -4px auto -5px 0);
- color: var(--text-muted-alt);
- cursor: default;
- }
- &-flow-icon {
- width: 15px;
- height: 24px;
- margin-top: 16px; /* compensate for h3 height */
- margin-left: 20px;
- margin-right: 20px;
- }
- &-controls {
- display: flex;
- @include bidi-style(margin-left, auto, margin-right, 0);
- align-self: flex-end;
- .btn {
- align-self: center;
- }
- }
- }
- /*
- datepicker resets some css it potentially inherits when its rendered inside a table
- */
- .datepicker {
- background: var(--background-tertiary);
- color: var(--text-inverted);
- padding: 0 14px 11px;
- position: absolute;
- min-width: 0;
- cursor: default;
- &.datepicker-rtl {
- left: auto;
- right: 0;
- }
- .datepicker-switch {
- padding: 12px 0;
- font-weight: bold;
- font-size: 15px;
- text-align: center;
- letter-spacing: 0;
- line-height: 1.5;
- text-transform: none;
- @extend %clickable;
- &:hover {
- background: hsl(240, 10%, 14%);
- }
- }
- th {
- background: none;
- font-weight: 500;
- }
- th,
- td {
- border: none;
- }
- .next,
- .prev {
- padding: 12px 9px 0;
- vertical-align: top;
- text-align: center;
- @extend %clickable;
- .icon {
- margin-top: 4px;
- fill: var(--text-inverted);
- opacity: 1;
- }
- &:hover {
- background: hsl(240, 10%, 14%);
- }
- }
- .dow {
- text-transform: uppercase;
- font-size: 12px;
- padding: 0;
- text-align: center;
- vertical-align: inherit;
- }
- td.cw {
- // background: 1px gap on the right towards the days + 1px border
- background: linear-gradient(
- to right,
- var(--background-modifier-lighter),
- var(--background-modifier-lighter) calc(100% - 2px),
- transparent calc(100% - 2px),
- var(--background-modifier-accent) calc(100% - 1px),
- transparent calc(100% - 1px)
- );
- padding: 0 5px 0 3px !important;
- text-align: center;
- border-radius: 0;
- }
- tbody td {
- width: 27px;
- height: 27px;
- border-radius: 14px;
- padding: 1px 0 0 !important;
- background-color: inherit;
- vertical-align: inherit;
- }
- .month,
- .year {
- float: left;
- width: 23%;
- margin: 1%;
- padding: 5px 0;
- }
- .day,
- .month,
- .year {
- text-align: center;
- &:not(.disabled) {
- @extend %clickable;
- }
- &.disabled,
- &.old,
- &.new {
- color: hsl(0, 0%, 33%);
- }
- &.today {
- background: #777;
- }
- &.focused {
- box-shadow: 0 0 0 1px hsl(207, 82%, 64%) inset;
- }
- &.active {
- color: var(--text-inverted);
- background: hsl(207, 82%, 64%);
- }
- }
- .today,
- .clear {
- text-align: center;
- padding: 2px 0 0;
- @extend %clickable;
- &.hidden {
- display: none;
- }
- }
- .datepicker-footer-buttons {
- display: flex;
- justify-content: space-between;
- gap: 20px;
- align-items: stretch;
- height: 31px;
- margin-top: 15px;
- div {
- flex-grow: 1;
- border: 1px solid #56575e;
- border-radius: 3px;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- }
- }
- #notify {
- position: absolute;
- top: 10px;
- left: 0;
- right: 0;
- @extend .zIndex-9;
- pointer-events: none;
- .noty_bar {
- max-width: 500px;
- text-align: center;
- margin: 0 auto 10px;
- .noty_message {
- pointer-events: auto;
- display: inline-block;
- background: rgba(0, 0, 0, 0.75);
- padding: 10px 15px 8px;
- border-radius: 3px;
- color: var(--text-inverted);
- }
- .icon {
- vertical-align: middle;
- margin-top: -3px;
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- a {
- color: inherit;
- text-decoration: none;
- }
- }
- }
- .animated {
- animation-duration: 300ms;
- animation-fill-mode: both;
- }
- .fadeInDown {
- animation-name: fadeInDown;
- }
- @keyframes fadeInDown {
- from {
- opacity: 0;
- transform: translate3d(0, -50%, 0);
- }
- to {
- opacity: 1;
- transform: none;
- }
- }
- .fadeOutDown {
- animation-name: fadeOutDown;
- }
- @keyframes fadeOutDown {
- from {
- opacity: 1;
- }
- to {
- opacity: 0;
- transform: translate3d(0, 50%, 0);
- }
- }
- .loading-placeholder {
- display: flex;
- align-items: center;
- justify-content: center;
- height: 133px;
- .loading-text {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- }
- .chat {
- flex: 1;
- display: flex;
- flex-direction: column;
- padding: 0 14px;
- @include phone {
- padding: 0;
- }
- .page-header {
- margin: 15px 0 5px;
- padding: 0 6px;
- @include phone {
- flex-wrap: wrap;
- margin: 0;
- padding: 5px 8px;
- }
- }
- .page-header-title {
- @include phone {
- order: 1;
- }
- }
- .page-header-center {
- @include phone {
- flex-basis: 100%;
- padding: 0;
- order: 3;
- }
- }
- .page-header-meta {
- @include phone {
- order: 2;
- @include bidi-style(margin-left, auto, margin-right, auto);
- padding-top: 4px;
- @include bidi-style(padding-left, 10px, padding-right, 0);
- }
- }
- }
- .chat-workspace {
- display: flex;
- flex-wrap: wrap;
- padding: 0 0 10px;
- margin: 0 -4px;
- flex: 1;
- @include phone {
- margin: 0;
- padding: 0;
- flex-wrap: nowrap;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- scroll-snap-mode: x mandatory;
- }
- }
- .chat-window {
- flex: 0 1 0;
- overflow: hidden;
- display: flex;
- flex-direction: column;
- transition-duration: 500ms;
- transition-property: transform, flex, padding;
- transform: scale(0);
- @include phone {
- min-width: calc(100vw - #{$mobileNavigationWidth} - 16px);
- scroll-snap-align: center;
- }
- &.is-open {
- flex: 1 0 25%;
- transform: scale(1);
- padding: 10px;
- @include phone {
- padding: 8px;
- }
- }
- &.is-offline {
- .chat-controls {
- opacity: 0.5;
- }
- }
- }
- .chat-header {
- background: var(--background-primary-alt);
- border: 1px solid var(--border-alt);
- border-radius: 3px 3px 0 0;
- height: 43px;
- line-height: 13px;
- flex-shrink: 0;
- display: flex;
- justify-content: space-between;
- align-items: center;
- }
- .chat-name {
- margin: 0 2px;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- .status-badge {
- @include bidi-style(margin-left, 2px, margin-right, 0);
- vertical-align: middle;
- height: 100%;
- }
- }
- .chat-status {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- &[data-status='online'] .icon {
- fill: var(--supergood-color);
- }
- &[data-status='offline'] .icon {
- fill: var(--superbad-color);
- }
- .icon-status-modified-inner-circle,
- .icon-status-modified-outer-circle {
- display: none;
- }
- &.is-modified {
- .icon-status {
- display: none;
- }
- .icon-status-modified-inner-circle,
- .icon-status-modified-outer-circle {
- display: block;
- }
- }
- }
- .chat-status-holder {
- position: relative;
- }
- .chat-disconnect,
- .chat-close {
- @extend %clickable;
- padding: 10px;
- .btn {
- min-width: 80px;
- justify-content: center;
- }
- }
- .chat-disconnect.is-hidden,
- .chat-close.is-hidden {
- display: none;
- }
- .chat-scroll-hint {
- background: var(--background-primary);
- display: flex;
- align-items: center;
- border: 1px solid var(--border-alt);
- border-top: none;
- padding: 7px 10px 6px;
- color: var(--text-muted);
- @extend %clickable;
- &.is-hidden {
- display: none;
- }
- .icon {
- fill: hsl(210, 5%, 78%);
- @include bidi-style(margin-right, 8px, margin-left, 0);
- }
- }
- .chat-body-holder {
- flex: 1;
- background: var(--background-secondary);
- font-size: 13px;
- line-height: 18px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- border-left: 1px solid var(--border-alt);
- border-right: 1px solid var(--border-alt);
- position: relative;
- }
- .chat-body-holder--standalone {
- border-top: 1px solid var(--border-alt);
- border-bottom: 1px solid var(--border-alt);
- }
- .chat-body {
- padding: 10px;
- display: flex;
- flex-direction: column;
- align-items: flex-start;
- position: absolute;
- width: 100%;
- top: 0;
- left: 0;
- }
- .chat-timestamp,
- .chat-notice-message {
- font-size: 12px;
- color: var(--text-muted);
- margin-bottom: 4px;
- align-self: center;
- word-break: break-word;
- }
- .chat-timestamp-label {
- font-weight: 500;
- }
- .chat-message {
- max-width: 90%;
- background: var(--background-primary);
- padding: 6px 12px;
- border-radius: 16px;
- margin-bottom: 4px;
- }
- .chat-message img {
- @extend %clickable;
- }
- .chat-message--customer.chat-message--new {
- font-weight: bold;
- }
- .chat-message--agent {
- @include bidi-style(margin-left, auto, margin-right, 0);
- background: var(--background-article-customer);
- align-self: flex-end;
- }
- .chat-message--agent + .chat-message--customer,
- .chat-message--customer + .chat-message--agent {
- margin-top: 10px;
- }
- .chat-status-message {
- align-self: center;
- background: var(--background-primary-alt);
- padding: 6px 12px;
- margin: 4px 0 10px;
- border-radius: 3px;
- }
- .chat-loader {
- @include bidi-style(margin-right, -4px, margin-left, 0);
- .icon {
- width: 12px;
- height: 12px;
- fill: var(--border);
- @include bidi-style(margin-left, -4px, margin-right, 0);
- vertical-align: middle;
- animation: ease-in-out load-fade 600ms infinite alternate;
- }
- .icon + .icon {
- animation-delay: 0.13s;
- }
- .icon + .icon + .icon {
- animation-delay: 0.26s;
- }
- }
- @keyframes load-fade {
- 0% {
- opacity: 0.5;
- transform: scale(0.6);
- }
- 67% {
- opacity: 1;
- transform: scale(1);
- }
- }
- .chat-footer {
- border-top: 1px solid var(--border-alt);
- padding: 10px 10px 0;
- display: flex;
- justify-content: center;
- align-self: stretch;
- margin: 0 -10px;
- }
- .chat-controls {
- display: flex;
- align-items: flex-start;
- padding: 10px;
- background: var(--background-primary-alt);
- border: 1px solid var(--border-alt);
- border-radius: 0 0 3px 3px;
- flex-shrink: 0;
- }
- .chat-input {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- flex-grow: 1;
- position: relative;
- .form-control {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- max-height: 50vh;
- }
- }
- .manage-chat-jquery-switch-container {
- display: flex;
- flex-direction: row;
- align-items: center;
- .zammad-switch {
- @include bidi-style(margin-right, 8px, margin-left, 8px);
- }
- }
- .browser {
- margin: 0 0 20px;
- position: relative;
- &[data-size] {
- padding-bottom: 65%; // 16:10 aspect ratio;
- .browser-ratio {
- width: 100%;
- height: 100%;
- position: absolute;
- left: 0;
- top: 0;
- transition: width 500ms;
- display: flex;
- flex-direction: column;
- }
- .browser-body {
- padding: 0;
- }
- }
- &[data-size='mobile'] .browser-ratio {
- width: 375px;
- }
- &-ratio {
- border: 1px solid var(--border);
- border-radius: 5px;
- }
- }
- /* stylelint-disable media-query-no-invalid */
- @media screen and (min-width: #{1280 + $sidebarWidth + $navigationWidth}) {
- // hide 1:1 button when it gets inrelevant
- [data-size='1:1'] {
- display: none;
- }
- .browser[data-size='mobile'] .browser-ratio {
- width: 500px;
- }
- }
- /* stylelint-enable media-query-no-invalid */
- .browser-body {
- flex: 1;
- position: relative;
- overflow: hidden;
- padding: 20px;
- &-inner {
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- }
- .browser-website {
- position: relative;
- height: 100%;
- transform-origin: right bottom;
- transition: 500ms;
- overflow: hidden;
- &.is-picking {
- cursor:
- image_url('/assets/images/eyedropper.gif') 0 15,
- auto;
- }
- &-background {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- object-fit: cover;
- object-position: left top;
- }
- }
- }
- .browser-head {
- display: flex;
- padding: 10px;
- border-bottom: 1px solid var(--border);
- .browser-input {
- position: relative;
- flex: 1;
- @include bidi-style(margin-right, 10px, margin-left, 0);
- input {
- min-width: 0;
- @include bidi-style(padding-right, 40px, padding-left, 12px);
- &.is-loading + .loading.icon {
- display: block;
- }
- }
- .loading.icon {
- position: absolute;
- @include bidi-style(right, 11px, left, auto);
- top: 10px;
- display: none;
- }
- }
- .help-block {
- margin-bottom: -3px;
- }
- }
- .browser-inline-form {
- width: 300px;
- &.no-css {
- all: initial;
- * {
- all: unset;
- }
- input,
- textarea,
- button {
- padding: 2px;
- background: var(--background-secondary);
- border: 1px solid;
- font: 400 11px system-ui;
- }
- button {
- padding: 2px 6px 3px;
- background-color: buttonface;
- border: 2px outset buttonface;
- }
- }
- }
- .chat-demo {
- .zammad-chat {
- position: absolute;
- transform-origin: right bottom;
- transition: 500ms;
- user-select: none;
- will-change: transform;
- &.is-fullscreen {
- right: 0;
- width: 100%;
- height: 100%;
- border-radius: 0 !important;
- .zammad-chat-header {
- border-radius: 0 !important;
- box-shadow:
- 0 -1px rgba(0, 0, 0, 0.1),
- 0 -1px rgba(0, 0, 0, 0.1) inset,
- 0 1px 1px rgba(0, 0, 0, 0.13);
- }
- .zammad-chat-controls {
- border-radius: 0 0 5px 5px;
- }
- }
- &.no-transition {
- transition: none;
- }
- .zammad-chat-welcome {
- display: block !important;
- }
- .zammad-chat-header-icon-open {
- display: inline !important;
- }
- .zammad-chat-agent-status,
- .zammad-chat-header-icon-close,
- .zammad-chat-agent {
- display: none !important;
- }
- &.is-open {
- .zammad-chat-agent {
- display: block !important;
- }
- .zammad-chat-header-icon-close,
- .zammad-chat-agent-status {
- display: inline-block !important;
- }
- .zammad-chat-welcome,
- .zammad-chat-header-icon-open {
- display: none !important;
- }
- }
- &.is-fullscreen {
- height: 100%;
- .zammad-chat-controls {
- border-radius: 0 0 5px 5px;
- }
- }
- }
- .zammad-chat-header {
- pointer-events: auto;
- }
- .chat-demo-animationHolder {
- position: absolute;
- bottom: 0;
- left: 0;
- width: 100%;
- height: 100%;
- animation: slide-up 500ms;
- pointer-events: none;
- }
- }
- @keyframes slide-up {
- from {
- transform: translateY(100%);
- }
- }
- .todo {
- position: relative;
- display: block;
- &:not(a) {
- cursor: default !important;
- }
- .icon {
- fill: var(--ghost-color) !important;
- vertical-align: middle;
- margin: -2px 3px 0 0;
- }
- &.is-done .icon {
- fill: var(--supergood-color) !important;
- }
- }
- .columnSelect {
- height: 234px;
- display: flex;
- padding: 0;
- line-height: 22px;
- &-shadow {
- display: none;
- }
- &-column--selected {
- flex: 1 1 66%;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- padding: 7px;
- }
- &-column--sidebar {
- flex-basis: 33%;
- flex-shrink: 1;
- border-left: 1px solid var(--border);
- background: var(--background-modifier-accent);
- display: flex;
- flex-direction: column;
- min-width: 0;
- .columnSelect-option:hover {
- background: var(--background-modifier-hover);
- }
- }
- &-pool {
- flex: 1 1 auto;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- padding: 7px;
- }
- &-option {
- @extend %clickable;
- padding: 0 5px;
- border-radius: 1px;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- &:hover {
- background: var(--background-modifier-hover);
- }
- }
- &-group-label {
- opacity: 0.5;
- .filter-active & {
- display: none;
- }
- ~ .columnSelect-option {
- padding-left: 10px;
- }
- }
- .is-hidden,
- .is-filtered {
- display: none;
- }
- &-search {
- position: relative;
- .icon-magnifier {
- left: 7px;
- top: 5px;
- position: absolute;
- opacity: 0.3;
- }
- &-clear {
- position: absolute;
- right: 0;
- top: 0;
- padding: 6px 7px 4px;
- @extend %clickable;
- line-height: 1;
- .icon {
- opacity: 0.6;
- }
- }
- input {
- width: 100%;
- padding: 2px 30px 1px;
- border: none;
- outline: none;
- border-bottom: 1px solid var(--border);
- background: none;
- }
- }
- }
- .pulsate-animation {
- animation: pulsate 667ms ease-in-out infinite alternate;
- }
- .richtext-content {
- overflow-x: auto;
- &[contenteditable] {
- &,
- &:hover,
- &:focus {
- background: none;
- }
- }
- h1,
- h2,
- h3,
- h4 {
- &:first-child {
- margin-top: 6px;
- }
- }
- table,
- pre,
- blockquote {
- margin-bottom: 16px;
- }
- & > p,
- & > table,
- & > pre,
- & > blockquote {
- &:first-child {
- margin-top: 6px;
- }
- &:last-child {
- margin-bottom: 6px;
- }
- }
- table {
- table-layout: auto;
- width: 100%;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- word-break: keep-all;
- col {
- width: auto;
- }
- span,
- p,
- a {
- overflow-wrap: anywhere;
- }
- }
- blockquote {
- padding: 8px 12px;
- border-left: 5px solid var(--background-primary-alt);
- }
- code {
- border: none;
- white-space: pre-wrap;
- }
- pre {
- padding: 12px 15px;
- font-size: 13px;
- line-height: 1.45;
- background: var(--background-modifier-accent-light);
- white-space: pre-wrap;
- border-radius: 3px;
- border: none;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- hr {
- margin-top: 6px;
- margin-bottom: 6px;
- border: 0;
- border-top: 1px solid var(--background-modifier-border);
- }
- @include dark {
- // remove custom backgrounds and colors
- [style*='background'] {
- background: none !important;
- }
- [style*='color'] {
- color: inherit !important;
- }
- }
- }
- .detail-search-header {
- margin: 20px 0 32px;
- }
- .batch-overlay {
- @extend .fit, .zIndex-1;
- color: var(--text-inverted);
- text-transform: uppercase;
- text-align: center;
- letter-spacing: 0.07em;
- font-size: 0.95em;
- line-height: 1.3;
- display: none;
- will-change: display;
- cursor: grabbing;
- overflow: hidden;
- user-select: none;
- &.is-visible {
- display: block;
- }
- &-backdrop {
- @extend .fit;
- background: hsla(231, 20%, 8%, 0.8);
- opacity: 0;
- will-change: opacity;
- }
- &-circle {
- margin: 35px auto;
- background: hsl(207, 7%, 29%);
- border-radius: 100%;
- border: 4px solid var(--background-secondary);
- width: 140px;
- height: 140px;
- padding: 20px 0;
- display: flex;
- flex-direction: column;
- justify-content: space-around;
- align-items: center;
- position: absolute;
- left: 0;
- right: 0;
- will-change: transform, opacity;
- visibility: hidden;
- &--top {
- top: 0;
- }
- &--bottom {
- bottom: 0;
- }
- .icon {
- fill: currentColor;
- opacity: 1;
- }
- &-label {
- width: 80%;
- margin: 10px 0;
- }
- }
- &-cancel {
- background: hsla(0, 0%, 100%, 0.21);
- background-clip: padding-box;
- border: 2px dashed hsla(0, 0%, 100%, 0.3);
- border-radius: 8px;
- padding: 28px;
- margin: auto 200px;
- position: absolute;
- left: 0;
- right: 0;
- max-height: 100px;
- visibility: hidden;
- will-change: opacity;
- display: flex;
- justify-content: center;
- align-items: center;
- }
- &-box {
- background: hsl(232, 9%, 17%);
- width: 100%;
- position: absolute;
- visibility: hidden;
- will-change: opacity, transition;
- &-inner {
- margin: 37px 25px;
- display: flex;
- flex-wrap: wrap;
- justify-content: center;
- overflow: hidden;
- }
- }
- &-assign {
- padding-bottom: 50px;
- bottom: -50px; // extra space for bounce animation
- .batch-overlay-box-inner {
- max-height: 40vh;
- }
- &-group {
- box-shadow: 0 0 35px hsla(0, 0%, 0%, 0.5);
- .batch-overlay-box-inner {
- margin-top: 42px;
- margin-bottom: 10px;
- }
- &-name {
- position: absolute;
- left: 0;
- right: 0;
- top: 0;
- padding: 11px 13px 8px;
- line-height: 1;
- position: absolute;
- background: hsl(233, 10%, 15%);
- }
- }
- &-entry {
- padding: 13px;
- width: 116px;
- height: 155px;
- &.is-hovered {
- .avatar {
- border-color: var(--highlight);
- transform: scale(1.05);
- }
- }
- .avatar {
- border: 4px solid hsl(231, 5%, 30%);
- margin-bottom: 10px;
- box-sizing: content-box;
- transition: transform 120ms;
- cursor: inherit;
- z-index: 1;
- }
- &-name {
- max-height: 34px;
- overflow: hidden;
- display: -webkit-box;
- -webkit-box-orient: vertical;
- -webkit-line-clamp: 2;
- overflow: hidden;
- word-break: break-word;
- }
- &-detail {
- color: gray;
- }
- }
- }
- &-macro {
- padding-top: 50px;
- top: -50px; // extra space for bounce animation
- .batch-overlay-box-inner {
- max-height: 55vh;
- margin: 24px 12px;
- }
- &-entry {
- margin: 13px;
- border: 4px solid hsl(231, 5%, 30%);
- background: hsl(233, 9%, 24%);
- border-radius: 100%;
- height: 120px;
- width: 120px;
- padding: 13px 13px 10px;
- display: flex;
- align-items: center;
- justify-content: center;
- font-size: 0.9em;
- &.is-hovered {
- border-color: var(--highlight);
- transform: scale(1.05);
- }
- &.small {
- @include small-desktop {
- height: 80px;
- width: 80px;
- padding: 11px 11px 8px;
- }
- }
- }
- &-error-message {
- margin: 13px;
- height: 120px;
- padding: 13px 13px 10px;
- display: flex;
- align-items: center;
- justify-content: center;
- font-size: 0.9em;
- }
- }
- }
- .batch-dragger {
- position: absolute;
- left: 0;
- top: 0;
- pointer-events: none;
- width: 250px;
- height: 40px;
- will-change: transform;
- @extend .zIndex-10;
- &-item {
- position: absolute;
- left: 0;
- width: 100%;
- background: var(--background-highlight);
- border-radius: 4px;
- display: flex;
- align-items: center;
- padding: 11px 0 9px 11px;
- box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.28);
- will-change: transform;
- a {
- color: inherit;
- }
- td:not(:first-child) {
- display: block;
- padding: 0 12px;
- white-space: nowrap;
- text-overflow: ellipsis;
- overflow: hidden;
- flex-shrink: 0;
- &:nth-child(3) {
- flex-shrink: 1;
- }
- &:nth-child(n + 4) {
- display: none;
- }
- }
- .checkbox-replacement > .icon,
- .radio-replacement > .icon {
- fill: none;
- }
- }
- &-counter {
- position: absolute;
- right: -8px;
- bottom: -8px;
- width: 25px;
- height: 25px;
- border-radius: 99px;
- z-index: 1;
- color: var(--text-inverted);
- background: var(--highlight);
- display: flex;
- align-items: center;
- justify-content: center;
- box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.28);
- will-change: transform;
- &:empty {
- display: none;
- }
- }
- }
- /*
- -------------
- breadcrumbs
- -------------
- */
- .breadcrumbs {
- display: flex;
- align-items: center;
- min-width: 88px;
- @include phone {
- overflow: hidden;
- }
- &-menu {
- display: flex;
- @include ltr(margin-left, auto);
- @include rtl(margin-right, auto);
- @include bidi-style(padding-left, 20px, padding-right, 0);
- @include phone {
- @include bidi-style(padding-left, 10px, padding-right, 0);
- }
- }
- }
- .breadcrumb {
- position: relative;
- padding-top: 11px;
- padding-bottom: 8px;
- @include ltr(padding-right, 21px);
- @include ltr(padding-left, 13px);
- @include rtl(padding-left, 21px);
- @include rtl(padding-right, 13px);
- color: inherit;
- cursor: pointer;
- @extend .u-textTruncate;
- @include phone {
- flex-shrink: 0;
- }
- &::before,
- &::after {
- content: '';
- position: absolute;
- width: 1px;
- height: 50%;
- background: currentColor;
- opacity: 0.33;
- @include ltr(right, 0);
- @include rtl(left, 0);
- top: 0;
- transform-origin: bottom;
- @include ltr(transform, rotate(-37deg));
- @include rtl(transform, rotate(37deg));
- }
- &::after {
- top: 50%;
- transform-origin: top;
- @include ltr(transform, rotate(37deg));
- @include rtl(transform, rotate(-37deg));
- }
- &:last-child {
- &::before,
- &::after {
- display: none;
- }
- }
- .modified-icon {
- @include bidi-style(margin-right, 3px, margin-left, 0);
- display: inline-block;
- vertical-align: middle;
- line-height: 1;
- margin-top: -3px;
- }
- &-icon {
- fill: currentColor;
- width: 20px;
- height: 20px;
- object-fit: contain;
- }
- .modified-icon-modifier {
- fill: var(--background-primary-alt);
- }
- }
- /*
- ---------------------
- iconfont icon picker
- ---------------------
- */
- .icon_picker {
- .dropdown-menu {
- max-height: 500px;
- width: 420px;
- min-width: 0;
- overflow-y: auto;
- }
- .controls {
- position: relative;
- }
- &-shadow {
- display: none;
- }
- .dropdown-grid {
- &:empty {
- padding: 0;
- & + .dropdown-filter-placeholder {
- display: block;
- }
- }
- li:hover:not(.is-active) {
- background: none;
- }
- .icon {
- width: 40px;
- line-height: 40px;
- text-align: center;
- }
- }
- .dropdown-filter-placeholder {
- display: none;
- padding: 10px;
- text-align: center;
- text-rendering: auto;
- font-feature-settings: 'liga';
- -webkit-font-smoothing: antialiased;
- -moz-osx-font-smoothing: grayscale;
- transition: letter-spacing 200ms;
- cursor: default;
- line-height: 40px;
- &:hover {
- letter-spacing: -2px;
- }
- span {
- display: none;
- &.is-active {
- display: block;
- }
- }
- }
- .dropdown-filter {
- background: none;
- width: 100%;
- background: var(--background-modifier-accent);
- border: none;
- padding: 13px 20px 11px;
- outline: none;
- }
- .dropdown-grid {
- display: flex;
- flex-wrap: wrap;
- padding: 10px;
- margin: 0;
- li {
- list-style: none;
- cursor: pointer;
- user-select: none;
- border-radius: 2px;
- &:hover,
- &.is-active {
- background: var(--highlight);
- }
- }
- }
- }
- /*
- --------------
- color picker
- --------------
- */
- .color {
- .controls {
- position: relative;
- }
- .controls-button {
- align-self: stretch;
- }
- .controls-button-inner {
- padding: 4px;
- }
- .color-field {
- width: 31px;
- height: 100%;
- position: relative;
- // unparsable color
- &[style='']::before {
- content: '';
- position: absolute;
- left: 10%;
- top: 10%;
- width: 80%;
- height: 80%;
- background: var(--background-primary-alt);
- animation: rotateplane 1.2s infinite ease-in-out;
- }
- }
- }
- .colorpicker {
- &.dropdown-menu {
- box-sizing: content-box;
- width: 380px;
- min-width: 0;
- }
- .open > & {
- display: flex;
- }
- &-hue-saturation {
- flex-grow: 1;
- width: 200px;
- height: 150px;
- margin: 14px;
- @include ltr(margin-right, 0);
- @include rtl(margin-left, 0);
- $i: 0;
- $rainbow: ();
- @while $i <= 360 {
- $rainbow: append($rainbow, unquote('hsl(#{$i},100%,50%)'), comma);
- $i: $i + 60;
- }
- background: linear-gradient(to right, $rainbow);
- position: relative;
- overflow: hidden;
- cursor:
- image_url('/assets/images/colorcircle.gif') 8 8,
- auto;
- user-select: none;
- }
- &-lightness-plane,
- &-saturation-gradient {
- position: absolute;
- left: 0;
- top: 0;
- height: 100%;
- width: 100%;
- }
- &-circle {
- position: absolute;
- left: 0;
- top: 0;
- border: 1px solid black;
- width: 12px;
- height: 12px;
- margin: -6px 0 0 -6px;
- border-radius: 100%;
- }
- &-lightness {
- height: 150px;
- margin: 14px;
- position: relative;
- user-select: none;
- }
- &-hue-plane {
- height: 100%;
- width: 20px;
- background: red;
- }
- &-hue-gradient {
- height: 100%;
- width: 100%;
- background: linear-gradient(white, transparent, black);
- }
- &-slider {
- position: absolute;
- top: 0;
- left: -7px;
- right: -7px;
- &-arrow {
- position: absolute;
- top: 0;
- margin-top: -4px;
- border: 4px solid transparent;
- border-left: 7px solid hsl(240, 8%, 100%);
- border-right: 7px solid hsl(240, 8%, 100%);
- &--left {
- left: 0;
- border-right: none;
- }
- &--right {
- right: 0;
- border-left: none;
- }
- }
- }
- }
- /*
- ----------------
- iconset picker
- ----------------
- */
- .iconset_picker {
- .controls input {
- display: none;
- }
- }
- .icon-sets {
- margin: 0 -10px;
- }
- .icon-set {
- margin: 10px;
- display: flex;
- border: 1px solid var(--border);
- border-radius: 3px;
- &.is-active {
- border-color: var(--border-highlight);
- box-shadow: 0 0 0 3px var(--shadow-highlight);
- }
- &-preview {
- flex-grow: 1;
- display: flex;
- flex-wrap: wrap;
- align-items: center;
- justify-content: center;
- overflow: hidden;
- cursor: pointer;
- user-select: none;
- height: 250px;
- border-radius: 0 3px 3px 0;
- border-left: 1px solid var(--border);
- background: var(--background-primary);
- color: var(--text-muted);
- position: relative;
- }
- &-meta {
- flex-basis: 197px;
- order: -1;
- display: flex;
- flex-direction: column;
- flex-shrink: 0;
- padding: 10px;
- background: var(--background-secondary);
- border-radius: 3px 0 0 3px;
- }
- &-version {
- color: var(--text-muted);
- }
- &-website {
- margin-top: auto;
- display: block;
- }
- .icon {
- width: 50px;
- line-height: 50px;
- text-align: center;
- font-size: 18px;
- &:not(.loading).do-flash {
- animation: iconset-flash 0.7s ease-out;
- }
- }
- }
- @keyframes iconset-flash {
- from {
- background: var(--background-modifier-hover);
- color: var(--text-normal);
- }
- to {
- background: transparent;
- color: inherit;
- }
- }
- /*
- -----------------------------
- generic flex layout classes
- -----------------------------
- */
- .horizontal,
- .vertical,
- .centered {
- display: flex;
- }
- .horizontal.hide,
- .vertical.hide,
- .centered.hide {
- display: none;
- }
- .horizontal {
- flex-direction: row;
- }
- .horizontal.multiline {
- flex-wrap: wrap;
- }
- .horizontal.reverse {
- flex-direction: row-reverse;
- }
- .vertical {
- flex-direction: column;
- }
- .vertical.reverse {
- flex-direction: column-reverse;
- }
- .vertical.stretch > *,
- .horizontal.stretch > * {
- flex: 1;
- }
- .stretch {
- align-self: stretch;
- }
- .relative {
- position: relative;
- }
- .fit {
- position: absolute;
- top: 0;
- left: 0;
- bottom: 0;
- right: 0;
- }
- body.fit {
- margin: 0;
- }
- .scrollable {
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- .flex {
- flex: 1;
- }
- .margin-bottom-5 {
- margin-bottom: 5px;
- }
- /*
- Firefox minimum content bugfix
- https://github.com/philipwalton/flexbugs#1-minimum-content-sizing-of-flex-items-not-honored
- "By default, flex items won’t shrink below their minimum
- content size (the length of the longest word or fixed-size element).
- To change this, set the min-width or min-height property."
- */
- .flex-shrink-horizontal {
- min-width: 0;
- }
- .flex-full {
- flex: 1 1 100%;
- }
- .flex-auto {
- flex: 1 1 auto;
- }
- .flex-shrink {
- flex: 0 1 auto;
- }
- .flex-no-shrink {
- flex-shrink: 0;
- }
- .flex-none {
- flex: none;
- }
- .flex-1 {
- flex: 1;
- }
- .flex-2 {
- flex: 2;
- }
- .flex-3 {
- flex: 3;
- }
- .justify-start {
- justify-content: flex-start;
- }
- .justified {
- justify-content: center;
- }
- .justify-end {
- justify-content: flex-end;
- }
- .justify-between {
- justify-content: space-between;
- }
- .start {
- align-items: flex-start;
- }
- .center {
- align-items: center;
- }
- .baseline {
- align-items: baseline;
- }
- .centered {
- align-items: center;
- justify-content: center;
- }
- .end {
- align-items: flex-end;
- }
- .self-start {
- align-self: start;
- }
- .self-end {
- align-self: end;
- }
- .span-width {
- flex-basis: 100%;
- }
- .two-columns,
- .three-columns,
- .wrap {
- flex-wrap: wrap;
- }
- .two-columns,
- .three-columns {
- @include phone {
- display: block;
- }
- }
- .two-columns > .column {
- width: 50%;
- @include phone {
- width: auto;
- }
- }
- .three-columns > .column {
- width: 33.33%;
- @include phone {
- width: auto;
- }
- }
- .align-left {
- @include bidi-style(margin-right, auto, margin-left, 0);
- }
- .align-right {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- .space-left {
- @include bidi-style(margin-left, 10px, margin-right, 0);
- }
- .space-right {
- @include bidi-style(margin-right, 10px, margin-left, 0);
- }
- .half-space-left {
- @include bidi-style(margin-left, 5px, margin-right, 0);
- }
- .half-space-right {
- @include bidi-style(margin-right, 5px, margin-left, 0);
- }
- .align-center {
- margin-left: auto;
- margin-right: auto;
- }
- .flex-space-after {
- @include bidi-style(margin-right, auto, margin-left, 0);
- }
- .flex-space-before {
- @include bidi-style(margin-left, auto, margin-right, 0);
- }
- .half-spacer {
- width: 5px;
- height: 5px;
- }
- .spacer {
- width: 10px;
- height: 10px;
- }
- .double-spacer {
- width: 20px;
- height: 20px;
- }
- .flex-spacer {
- flex: 1;
- }
- span.is-disabled {
- cursor: not-allowed;
- opacity: 0.5;
- }
- .inline-label + .scheduled-widget {
- margin-left: 18px;
- }
- .scheduled-widget {
- display: flex;
- align-items: center;
- padding: 5px 5px 5px 10px;
- border: 1px solid rgba(0, 0, 0, 0.1);
- border-radius: 4px;
- &[data-state='published'] {
- color: var(--supergood-color);
- border-color: currentColor;
- .btn {
- border-color: currentColor;
- }
- }
- &[data-state='archived'] {
- border-color: var(--ghost-color);
- .btn {
- border-color: var(--ghost-color);
- }
- }
- &[data-state='internal'] {
- color: var(--highlight);
- border-color: currentColor;
- .btn {
- border-color: currentColor;
- }
- }
- .help-text & {
- margin-top: 4px;
- }
- .icon {
- color: inherit;
- fill: currentColor;
- vertical-align: middle;
- }
- &-label {
- margin: 0 10px 0 6px;
- }
- .icon-diagonal-cross {
- width: 10px;
- height: 10px;
- }
- .btn {
- color: inherit;
- }
- }
- .knowledge-base {
- &-navigation {
- display: flex;
- align-items: center;
- color: var(--interactive-muted);
- background: var(--background-primary-alt);
- border-bottom: 1px solid var(--border);
- padding: 7px;
- @include phone {
- flex-shrink: 0;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- }
- .breadcrumb:not(:first-child) .breadcrumb-icon {
- width: 16px;
- height: 16px;
- }
- }
- &-body {
- position: relative;
- overflow-x: hidden;
- @include phone {
- flex-direction: column-reverse;
- overflow: visible;
- }
- }
- &-sidebar {
- position: absolute;
- @include ltr(right, 0);
- @include rtl(left, 0);
- top: 0;
- width: 280px;
- height: 100%;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- transition: transform 500ms;
- @include bidi-style(
- border-left,
- 1px solid var(--border),
- border-right,
- none
- );
- @include phone {
- width: auto;
- position: static;
- @include bidi-style(border-left, none, border-right, none);
- border-top: 1px solid var(--border);
- overflow: visible;
- }
- @include desktop {
- width: 28%;
- }
- &.hidden {
- display: block !important;
- visibility: visible !important;
- @include ltr(transform, translateX(100%));
- @include rtl(transform, translateX(-100%));
- @include phone {
- transform: none !important;
- display: none !important;
- }
- + .knowledge-base-main {
- @include ltr(margin-right, 0);
- @include rtl(margin-left, 0);
- }
- }
- h2 {
- font-size: 17px;
- line-height: 1;
- }
- }
- &-main {
- width: 100%;
- @include ltr(transition, margin-right 500ms);
- @include ltr(margin-right, 280px);
- @include rtl(transition, margin-left 500ms);
- @include rtl(margin-left, 280px);
- @include phone {
- margin: 0 0 10px !important;
- }
- @include desktop {
- @include ltr(margin-right, 28%);
- @include rtl(margin-left, 28%);
- }
- }
- form {
- flex-shrink: 0;
- }
- .richtext-content {
- word-break: break-word;
- word-wrap: anywhere;
- }
- .page-header {
- margin: 1px 0 3px;
- flex-shrink: 0;
- }
- }
- .modal-manage-attachments {
- input:focus + label {
- text-decoration: none;
- }
- }
- .modal-knowledge-base-server-snippet {
- label.radio-replacement:first-child {
- padding-left: 0;
- }
- }
- .container {
- max-width: 960px;
- width: 100%;
- margin: 20px auto;
- }
- .sections {
- list-style: none;
- padding: 0;
- margin: 0 -10px;
- &:not(:empty) + &:not(:empty) {
- border-top: 1px solid var(--border);
- margin-top: 20px;
- padding-top: 20px;
- }
- &--grid {
- display: flex;
- flex-wrap: wrap;
- .section {
- a {
- padding-bottom: 72%;
- position: relative;
- line-height: 1.3;
- }
- [data-font] {
- font-size: 60px;
- }
- .modified-icon {
- margin: 10px 0 20px;
- }
- &--subsection {
- display: none;
- }
- &-inner {
- position: absolute;
- padding: 10px;
- left: 0;
- top: 0;
- right: 0;
- bottom: 0;
- align-items: center;
- justify-content: center;
- flex-direction: column;
- text-align: center;
- .title {
- display: -webkit-box;
- overflow: auto;
- -webkit-box-orient: vertical;
- -webkit-line-clamp: 5;
- }
- }
- }
- &[data-size='medium'] {
- .section {
- width: 25%;
- @include phone {
- width: 100%;
- }
- a {
- font-size: 14px;
- }
- [data-font] {
- font-size: 42px;
- }
- .modified-icon-modifier {
- width: 18px;
- height: 18px;
- margin: 0 -6px -2px 0;
- }
- }
- }
- &[data-size='large'] {
- .section {
- width: 33.33%;
- @include phone {
- width: 100%;
- }
- a {
- font-size: 15px;
- }
- .modified-icon-modifier {
- width: 22.5px;
- height: 22.5px;
- margin: 0 -8px -5px 0;
- }
- }
- }
- }
- &--list {
- .section-detail {
- margin-left: 0.2em;
- }
- }
- }
- .section {
- &.kb-item--invisible {
- opacity: 0.5;
- }
- &.kb-item--missing-translation,
- &.kb-item--missing-translation:active,
- &.kb-item--missing-translation:focus {
- color: hsl(45, 98%, 63%);
- }
- a {
- display: block;
- text-decoration: none;
- color: inherit;
- }
- &-title {
- color: #444a4f;
- }
- &-detail {
- color: #b4b7b9;
- }
- }
- .section-inner {
- position: relative;
- display: flex;
- align-items: flex-start;
- padding: 10px 14px;
- margin: 10px;
- background: var(--background-secondary);
- border-radius: 3px;
- border: 1px solid var(--border);
- box-shadow: var(--elevation-low);
- @include phone {
- margin: 5px;
- }
- &:active {
- box-shadow: none;
- }
- &-title {
- font-weight: 500;
- font-size: 15px;
- line-height: 1.15;
- }
- &-date {
- display: inline;
- color: hsl(0, 0%, 75%);
- &::after {
- content: ' — ';
- color: var(--text-normal);
- }
- &:only-child::after {
- content: '';
- }
- }
- &-detail {
- display: block;
- margin-top: 5px;
- }
- &-icon {
- flex-shrink: 0;
- vertical-align: middle;
- &-holder {
- @include ltr(margin-right, 11px);
- @include rtl(margin-left, 11px);
- margin-top: 1px;
- .nav-pills & {
- @include ltr(margin-right, 7px);
- @include rtl(margin-left, 7px);
- }
- }
- &[data-font] {
- font-size: 16px;
- line-height: 1;
- }
- &.icon {
- fill: currentColor;
- width: 16px;
- height: 16px;
- object-fit: contain;
- object-position: center top;
- }
- }
- em {
- font-style: normal;
- background: hsla(205, 90%, 60%, 0.75);
- }
- }
- .knowledge-base-article {
- &-header {
- text-align: center;
- }
- &-meta {
- display: block;
- text-align: center;
- > * {
- &:first-child {
- text-transform: capitalize;
- }
- &::after {
- content: ' · ';
- }
- &:last-child::after {
- display: none;
- }
- }
- }
- &-body {
- margin-top: 20px;
- background: var(--background-secondary);
- border-radius: 2px;
- padding: 50px 50px 10px;
- border: 1px solid var(--border);
- @include phone {
- padding: 15px 15px 5px;
- }
- }
- &-content {
- margin-bottom: 40px;
- @include phone {
- margin-bottom: 10px;
- }
- }
- &-attachments,
- &-tags,
- &-linked-tickets {
- margin: 0 -30px;
- @include phone {
- margin: 0 -5px;
- }
- }
- .tasks {
- @include bidi-style(margin-left, 7px, margin-right, 0);
- }
- &-tags--container {
- padding: 6px 5px 11px;
- display: flex;
- flex-wrap: wrap;
- .tag {
- margin: 2px;
- display: inline-block;
- background: #0f94d6;
- color: var(--text-inverted);
- border-radius: 999px;
- padding: 2px 12px 1px;
- &:hover {
- background: hsl(200deg, 87%, 34%);
- }
- }
- }
- &-nav {
- display: flex;
- &-link {
- padding: 15px;
- max-width: 50%;
- display: flex;
- align-items: center;
- .knowledge-base-article > & {
- margin-top: -10px;
- }
- .spacer {
- width: 5px;
- }
- .icon {
- flex-shrink: 0;
- fill: currentColor;
- opacity: 1;
- vertical-align: top;
- }
- &--next {
- @include bidi-style(margin-left, auto, margin-right, inherit);
- }
- &-title {
- @extend .u-textTruncate;
- }
- }
- }
- }
- .miller-columns {
- display: flex;
- font-size: 12px;
- border: 1px solid var(--border);
- border-radius: 3px;
- .column {
- list-style: none;
- padding: 0;
- margin: 0;
- flex: 1 1 33%;
- height: 300px;
- overflow: auto;
- -webkit-overflow-scrolling: touch;
- border-right: 1px solid var(--border);
- &:last-child {
- border-right-width: 0;
- }
- &-item {
- display: flex;
- align-items: center;
- padding: 5px 10px;
- cursor: default;
- &:hover {
- background: var(--background-modifier-accent-light);
- }
- &.is-selected {
- background: var(--background-secondary-hover);
- }
- &--has-children {
- @extend %clickable;
- cursor: pointer;
- }
- span {
- @extend .u-textTruncate;
- margin-right: 10px;
- }
- > .icon:first-child,
- [data-font] {
- fill: currentColor;
- margin-right: 8px;
- vertical-align: middle;
- flex-shrink: 0;
- }
- .icon-arrow-right {
- margin-left: auto;
- flex-shrink: 0;
- }
- .btn {
- margin-left: auto;
- }
- }
- }
- }
- .highlight-emulator {
- background-color: highlight;
- }
- .videoWrapper {
- position: relative;
- padding-bottom: 56.25%; /* 16:9 */
- padding-top: 25px;
- height: 0;
- }
- .videoWrapper iframe {
- position: absolute;
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- }
- .btn-manage-public-menu-edit {
- margin-top: 0;
- }
- .kb-menu-settings-entry {
- margin-bottom: 12px;
- }
- .text-modules-box {
- max-height: 40vh;
- }
- .sla_times {
- .sla_radio_container {
- padding-top: 0.5em;
- padding-left: 0.5em;
- }
- }
- .calendar-preview {
- .calendar-events {
- margin-top: 12px;
- p {
- margin: 0;
- }
- h2 {
- margin-bottom: 24px;
- }
- h4 {
- margin-bottom: 4px;
- }
- section.description {
- margin: 24px 0 0;
- padding: 4px;
- }
- .event-row {
- display: flex;
- div {
- width: 50%;
- margin-bottom: 4px;
- }
- }
- }
- div.divider {
- margin-top: 18px;
- margin-bottom: 6px;
- border-top: 1px solid #dfdfdf;
- &:last-of-type {
- display: none;
- }
- }
- }
- .reporting {
- .legend > div {
- background: var(--background-secondary) !important;
- }
- .legendColorBox {
- padding-right: 4px;
- }
- }
- .duplicate-ticket-detection {
- position: relative;
- margin-bottom: 0;
- .close {
- position: absolute;
- top: 2px;
- opacity: 0.39;
- @include bidi-style(right, 0, left, 0);
- &:hover {
- opacity: 1;
- }
- svg {
- width: 9px;
- height: 9px;
- }
- }
- h4 {
- text-transform: none;
- font-size: 16px;
- }
- p {
- word-wrap: break-word;
- overflow-wrap: break-word;
- white-space: pre-wrap;
- }
- p,
- ul {
- margin-bottom: 6px;
- }
- .btn {
- font-size: 10px;
- color: var(--text-link);
- background: none;
- }
- }
- .profile-settings-notifications-content {
- .zammad-switch {
- float: left;
- margin-right: 10px;
- }
- .profile-groups-limit-settings {
- min-height: 1px;
- }
- .settings-list {
- margin-bottom: 0;
- }
- .profile-groups-all-unchecked {
- margin-bottom: 10px;
- }
- }
- .profile-two-factor {
- table {
- margin-bottom: 16px;
- }
- .recovery-codes {
- p {
- margin: 12px 0;
- }
- p:last-of-type {
- margin: 0;
- }
- }
- }
- .two-factor-auth {
- .loading {
- display: block;
- margin: 25px auto;
- }
- &-method-buttons {
- display: flex;
- flex-direction: column;
- max-width: 382px;
- margin: 25px auto 0;
- }
- &-method {
- display: flex;
- flex-direction: column;
- margin-bottom: 15px;
- }
- .is-disabled {
- opacity: 0.33;
- }
- .method-form .form-group {
- margin-bottom: 4px;
- }
- .authenticator-app {
- --width: 306px;
- --height: 306px;
- position: relative;
- width: var(--width);
- margin: 0 auto;
- .qr-code-canvas {
- width: var(--width);
- height: var(--height);
- cursor: pointer;
- }
- .secret {
- position: absolute;
- top: 0;
- left: 0;
- width: var(--width);
- height: var(--height);
- background: rgba(0, 0, 0, 0.9);
- color: var(--text-inverted);
- font-family: monospace;
- display: flex;
- justify-content: center;
- align-items: center;
- cursor: pointer;
- }
- }
- }
- .history-row-list {
- padding-left: 10px;
- span {
- text-decoration: underline;
- }
- }
- .btn--split--last.js-securitySign {
- .icon {
- @include ltr(margin, -2px 5px 0 -2px !important);
- @include rtl(margin, -2px -2px 0 5px !important);
- }
- }
- .overlap-x-6 {
- @include ltr(margin-left, -6px);
- @include rtl(margin-right, -6px);
- }
- div.accounted-time-value {
- &-container {
- display: flex;
- flex-direction: column;
- }
- &-row {
- display: flex;
- flex-direction: row;
- }
- &-item {
- padding: 1px;
- flex: 0 0 auto;
- }
- &-item:first-child {
- flex: 1 1 auto;
- white-space: nowrap;
- text-overflow: ellipsis;
- overflow: hidden;
- @include bidi-style(margin-right, 6px, margin-left, 0);
- }
- }
|